我有一个表,有几个可空的整数列。出于几个原因,这是不可取的,因此我希望将所有空值更新为0,然后将这些列设置为NOT NULL。除了将null更改为0之外,还必须保留数据。
我正在寻找特定的SQL语法来更改列(称为ColumnA)为“非空”。假设数据已更新为不包含空值。
使用SQL server 2000。
我有一个表,有几个可空的整数列。出于几个原因,这是不可取的,因此我希望将所有空值更新为0,然后将这些列设置为NOT NULL。除了将null更改为0之外,还必须保留数据。
我正在寻找特定的SQL语法来更改列(称为ColumnA)为“非空”。假设数据已更新为不包含空值。
使用SQL server 2000。
当前回答
对于JDK (Oracle支持的Apache Derby发行版)中包含的内置javaDB,下面的方法对我来说是有效的
alter table [table name] alter column [column name] not null;
其他回答
首先,使所有当前NULL值消失:
UPDATE [Table] SET [Column]=0 WHERE [Column] IS NULL
然后,更新表定义以禁止“null”:
ALTER TABLE [Table] ALTER COLUMN [Column] INTEGER NOT NULL
只要列不是唯一标识符即可
UPDATE table set columnName = 0 where columnName is null
Then
修改表并将字段设置为非空,并指定默认值为0
让我们举个例子:
TABLE NAME=EMPLOYEE
我想将EMPLOYEE_NAME列更改为NOT NULL。此查询可用于以下任务:
ALTER TABLE EMPLOYEE MODIFY EMPLOYEE.EMPLOYEE_NAME datatype NOT NULL;
对于JDK (Oracle支持的Apache Derby发行版)中包含的内置javaDB,下面的方法对我来说是有效的
alter table [table name] alter column [column name] not null;
首先,确保您更改为not的列没有空值 从列_name为空的表中选择count(*) 输入缺失的值。你可以用空字符串、0、平均值、中值或插值值替换空值。这取决于你的后填充策略或前填充策略。 决定列值是唯一的还是非唯一的。如果它们需要是唯一的,那么就添加一个唯一的约束。否则,查看性能是否足够,或者是否需要添加索引。