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

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

使用SQL server 2000。


当前回答

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

ALTER TABLE tablename MODIFY columnname datatype NOT NULL;

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

其他回答

首先,使所有当前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

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

ALTER TABLE mytable modify mycolumn datatype NOT NULL;

对于JDK (Oracle支持的Apache Derby发行版)中包含的内置javaDB,下面的方法对我来说是有效的

alter table [table name] alter column [column name] not null;

这招对我很管用:

ALTER TABLE [Table] 
Alter COLUMN [Column] VARCHAR(50) not null;