我有一个表,有几个可空的整数列。出于几个原因,这是不可取的,因此我希望将所有空值更新为0,然后将这些列设置为NOT NULL。除了将null更改为0之外,还必须保留数据。

我正在寻找特定的SQL语法来更改列(称为ColumnA)为“非空”。假设数据已更新为不包含空值。

使用SQL server 2000。


当前回答

只要列不是唯一标识符即可

UPDATE table set columnName = 0 where columnName is null

Then

修改表并将字段设置为非空,并指定默认值为0

其他回答

对于Oracle 11g,我能够更改列属性如下:

ALTER TABLE tablename MODIFY columnname datatype NOT NULL;

除此之外,阿巴契夫的回答似乎还不错。您不能重复更改—它会提示(至少在SQL Developer中)该列已经不是空的。

您可以使用以下sql更改现有DB列的定义。

ALTER TABLE mytable modify mycolumn datatype NOT NULL;

在外键约束的情况下…如果“0”不在主键表的列中,就会出现问题。解决办法是……

步骤1:

使用以下代码禁用所有约束:

EXEC sp_msforeachtable "ALTER TABLE ? NOCHECK CONSTRAINT all"

步骤2:

RUN UPDATE COMMAND (as mentioned in above comments)
RUN ALTER COMMAND (as mentioned in above comments)

步骤3:

使用以下代码启用所有约束:

exec sp_msforeachtable @command1="print '?'", @command2="ALTER TABLE ? WITH CHECK CHECK CONSTRAINT all"

在我的情况下,我对张贴的答案有困难。我最终使用了以下方法:

ALTER TABLE table_name CHANGE COLUMN column_name column_name VARCHAR(200) NOT NULL DEFAULT '';

将VARCHAR(200)更改为您的数据类型,并可选择更改默认值。

如果你没有一个默认值,你将有一个问题,因为默认值将为null,从而产生冲突。

你需要分两步完成:

更新表,使列中没有空值。

UPDATE MyTable SET MyNullableColumn = 0
WHERE MyNullableColumn IS NULL

更改表以更改列的属性

ALTER TABLE MyTable
ALTER COLUMN MyNullableColumn MyNullableColumnDatatype NOT NULL