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

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

使用SQL server 2000。


当前回答

这看起来更简单,但只适用于Oracle:

ALTER TABLE [Table] 
ALTER [Column] NUMBER DEFAULT 0 NOT NULL;

此外,您还可以使用它添加列,而不仅仅是更改它。 如果默认值为空,则更新为本例中的默认值(0)。

其他回答

我有同样的问题,但字段过去默认为null,现在我想把它默认为0。这需要在mdb的解决方案后再添加一行:

ALTER TABLE [Table] ADD CONSTRAINT [Constraint] DEFAULT 0 FOR [Column];

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

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;

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

ALTER TABLE mytable modify mycolumn datatype NOT NULL;

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

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

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

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