设置字段是否可以为空

设置字段非空

在设置之前首先要确保该字段存在数据。

Oracle:

ALTER TABLE TABLE_NAME MODIFY FIELD_NAME NOT NULL;

DB2:

ALTER TABLE TABLE_NAME ALTER COLUMN FIELD_NAME SET NOT NULL;

设置字段可以为空

Oracle:

ALTER TABLE TABLE_NAME MODIFY FIELD_NAME NULL;

DB2:

ALTER TABLE TABLE_NAME ALTER COLUMN FIELD_NAME DROP NOT NULL;

设置字段默认值

设置默认值为空,即没有默认值

Oracle:

ALTER TABLE TABLE_NAME MODIFY FILED_NAME DEFAULT NULL;

DB2:

ALTER TABLE TABLE_NAME ALTER COLUMN FILED_NAME DROP DEFAULT;

设置一个默认值

Oracle:

ALTER TABLE TABLE_NAME MODIFY FILED_NAME DEFAULT VALUE;

DB2:

ALTER TABLE TABLE_NAME ALTER COLUMN FILED_NAME SET DEFAULT 0;

删除主键约束同时删除同名的索引

删除主键约束的同时是否会删除同名的索引,取决于该同名的索引是创建主键约束时自动创建的,还是创建主键约束前手动创建的。

当我们用如下语句创建主键约束时,会自动创建同名的索引:

ALTER TABLE TABLE_NAME ADD CONSTRAINT CONSTRAINT_NAME PRIMARY KEY (FIELD1, FIELD2, FIELD3);

这个索引在主键约束被删除时会自动被删除:

ALTER TABLE TABLE_NAME DROP CONSTRAINT CONSTRAINT_NAME;

如果换一种方式:

1. 先创建主键索引

CREATE UNIQUE INDEX CONSTRAINT_NAME ON TABLE_NAME (FIELD1, FIELD2, FIELD3);

2. 再创建主键约束

ALTER TABLE TABLE_NAME ADD CONSTRAINT CONSTRAINT_NAME PRIMARY KEY (FIELD1, FIELD2, FIELD3);

这时,再通过

ALTER TABLE TABLE_NAME DROP CONSTRAINT CONSTRAINT_NAME;

无法删除索引,只能删除主键约束。经测试,这个在Oracle和DB2下面表现是一致的。

在Oracle数据库下,可以通过如下语句把主键约束和索引一起删除:

ALTER TABLE TABLE_NAME DROP CONSTRAINT CONSTRAINT_NAME CASCADE DROP INDEX;

DB2下暂时不知道用什么简单的语句,用存储过程是可以实现的。