给oracle的date字段加not null

已经建了一个表,其中a为date型,现在想将它设为not null,用:alter table tbl_aidp add(flag number(1) not null);不行,请问该怎么改呢?谢谢!

alter table modify a not null;
要这样才行。
不过前提如果这列中有空值了 你要先把空值删除 才能修改

补充,顺便记下oracle中对列的各种操作吧:
1.增加列

ALTER TABLE table_name ADD( column datatype [DEFAULT EXPR][,column datatype...]);

例如:

SQL>ALTER TABLE emp01 ADD eno NUMBER(4);

2.修改列定义

例如:

SQL>ALTER TABLE emp01 MODIFY job VARCHAR2(15)

2 DEFAULT 'CLERK'

3.删除列

例如:

SQL> ALTER TABLE emp01 DROP COLUMN dno;

4.修改列名

例如:

SQL>ALTER TABLE emp01 RENAME COLUMN eno TO empno;

5.修改表名

例如:

SQL>RENAME emp01 TO employee;

6.增加注释

例如:

SQL>COMMENT ON TABLE employee IS '存放雇员信息';

SQL>COMMENT ON TABLE employee.name IS '描述雇员姓名';
温馨提示:内容为网友见解,仅供参考
第1个回答  2009-11-06
直接编辑表结构,把为空的复选框选中去掉就可以了
相似回答