ORA-01758: 要添加必需的 (NOT NULL) 列, 則表必須為空白

來源:互聯網
上載者:User

給一個已經有記錄的表添加新列,並指定not null 時報ORA-01758。怎麼辦?

1.給新添加的列指定預設值。

2.清空表中的記錄再添加新列。

實驗如下:

  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>   

相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.