ORA-01758: 要添加必需的 (NOT NULL) 列, 则表必须为空

给一个已经有记录的表添加新列,并指定not null 时报ORA-01758。怎么办?

1.给新添加的列指定默认值。

2.清空表中的记录再添加新列。

实验如下:

[c-sharp] view plain copy print ?
  1. SQL> drop table ord;  
  2. Table dropped  
  3.   
  4. SQL> create table ORD  
  5.   2  (  
  6.   3    ORD_NO   NUMBER(2) not null,  
  7.   4    ORD_DATE DATE,  
  8.   5    CUST_ID  NUMBER(4)  
  9.   6  );  
  10.   
  11. Table created  
  12.   
  13. SQL> insert into ORD values(1,sysdate ,100);  
  14.   
  15. 1 row inserted  
  16.   
  17. SQL> COMMIT;  
  18.   
  19. Commit complete  
  20.   
  21. --表中有记录,添加新列,并指定not null时报ORA-01758  
  22.   
  23. SQL> ALTER TABLE ORD ADD price NUMBER(8,2) NOT NULL;  
  24.   
  25. ALTER TABLE ORD ADD price NUMBER(8,2) NOT NULL  
  26.   
  27. ORA-01758: 要添加必需的 (NOT NULL) 列, 则表必须为空  
  28.   
  29. -- 给新列指定默认值,可以添加。  
  30.   
  31. SQL> ALTER TABLE ORD ADD price NUMBER(8,2) DEFAULT 0 NOT NULL;  
  32.   
  33. Table altered  
  34.   
  35. --清空表中的记录,可以不指定默认值。这种比较少用。  
  36. SQL> TRUNCATE TABLE ORD;  
  37.   
  38. Table truncated  
  39.   
  40. SQL> alter table ORD drop column PRICE;  
  41.   
  42. Table altered  
  43.   
  44. SQL> ALTER TABLE ORD ADD price NUMBER(8,2) NOT NULL;  
  45.   
  46. Table altered  
  47.   
  48. SQL>   

come from:http://blog.csdn.net/lwei_998/article/details/6060317

 

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/90618/viewspace-733317/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/90618/viewspace-733317/

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值