我有一个表,有几个可空的整数列。出于几个原因,这是不可取的,因此我希望将所有空值更新为0,然后将这些列设置为NOT NULL。除了将null更改为0之外,还必须保留数据。
我正在寻找特定的SQL语法来更改列(称为ColumnA)为“非空”。假设数据已更新为不包含空值。
使用SQL server 2000。
我有一个表,有几个可空的整数列。出于几个原因,这是不可取的,因此我希望将所有空值更新为0,然后将这些列设置为NOT NULL。除了将null更改为0之外,还必须保留数据。
我正在寻找特定的SQL语法来更改列(称为ColumnA)为“非空”。假设数据已更新为不包含空值。
使用SQL server 2000。
当前回答
你需要分两步完成:
更新表,使列中没有空值。
UPDATE MyTable SET MyNullableColumn = 0
WHERE MyNullableColumn IS NULL
更改表以更改列的属性
ALTER TABLE MyTable
ALTER COLUMN MyNullableColumn MyNullableColumnDatatype NOT NULL
其他回答
对于Oracle 11g,我能够更改列属性如下:
ALTER TABLE tablename MODIFY columnname datatype NOT NULL;
除此之外,阿巴契夫的回答似乎还不错。您不能重复更改—它会提示(至少在SQL Developer中)该列已经不是空的。
您可以使用以下sql更改现有DB列的定义。
ALTER TABLE mytable modify mycolumn datatype NOT NULL;
我有同样的问题,但字段过去默认为null,现在我想把它默认为0。这需要在mdb的解决方案后再添加一行:
ALTER TABLE [Table] ADD CONSTRAINT [Constraint] DEFAULT 0 FOR [Column];
这招对我很管用:
ALTER TABLE [Table]
Alter COLUMN [Column] VARCHAR(50) not null;
让我们举个例子:
TABLE NAME=EMPLOYEE
我想将EMPLOYEE_NAME列更改为NOT NULL。此查询可用于以下任务:
ALTER TABLE EMPLOYEE MODIFY EMPLOYEE.EMPLOYEE_NAME datatype NOT NULL;