Oracle PL/SQL开发基础(第三弹:修改表)
2017-03-23 22:41
537 查看
修改表列
新增表列
如:ALTER TABLE invoice_check ADD invoice_name VARCHAR2(100);
还可以在添加列是定义列属性,如:
ALTER TABLE invoice_check ADD invoice_name VARCHAR2(100) CHECK(LENGTH(invoice_name)<=50);
修改表列
如:ALTER TABLE invoice_check MODIFY invoice_name VARCHAR2(100);
Oracle数据库不允许会引起数据库数据丢失的列更改,如果现在将invoice_name的长度变回20,将会引起异常:
SQL> ALTER TABLE invoice_check MODIFY invoice_name VARCHAR2(20); ALTER TABLE invoice_check MODIFY invoice_name VARCHAR2(20) * ERROR 位于第1行: ORA-01441:无法减小列长度,因为一些值过大
删除表列
如:ALTER TABLE invoice_check DROP COLUMN invoice_name;
上面的代码将删除
invoice_check表中的
invoice_name字段,无论字段中是否有值。
重命名表列
如:ALTER TABLE invoice_check RENAME COLUMN invoice_name TO invoice_name_short;
修改约束
添加约束
如:--添加主键约束 ALTER TABLE invoice_check ADD CONSTRAINT invoice_check_pk PRIMARY KEY (invoice_id); --添加检查约束 ALTER TABLE invoice_check_others ADD CONSTRAINT invoice_total_ck CHECK(invoice_total>=1); --添加外键约束 ALTER TABLE invoice_check_others ADD CONSTRAINT invoice_fk_vendors FOREIGN KEY (vendor_id) REFERENCES vendors(vendor_id); --添加NOT NULL约束 ALTER TABLE vendors ADD CONSTRAINT vendor_vendor_name_nn NOT NULL;
删除约束
如:--移除UNIQUE约束 ALTER TABLE invoice_check DROP CONSTRAINT invoice_check_nn;
删除数据表
使用DROP TABLE语句,可以删除数据表中所有的数据和数据表结构及约束,如:DROP TABLE invoice_check;
在使用DROP TABLE语句时,Oracle会检查要删除的 表是否存在与其他表的依赖关系,如果存在,Oracle将不允许删除。
比如invoice表中的
vendor_id与vendors表中的
vendor_id具有主外键关系,要能成功删除vendors表,必须首先删除invoice表,然后再删除vendors表。
Oracle还提供了在DROP TABLE语句中可以使用的CASCADE CONSTRAINTS语句来级联删除关联关系,如果使用:
DROP TABLE vendors CASCADE CONSTRAINTS;则vendors表被成功删除,同事删除了vendors表和invoice表之间的主外键约束,但是存储在invoice表中的数据并没有被删除,依然存在。
相关文章推荐
- Oracle PL/SQL开发基础(第八弹:ROWID伪列)
- Oracle PL/SQL开发基础(第十弹:子查询)
- Oracle PL/SQL开发基础(第二十五弹:操纵游标数据)
- Oracle PL/SQL开发基础(第二十二弹:类型转换函数)
- Oracle PL/SQL开发基础(第三十六弹:异常处理的一些经验)
- Oracle PL/SQL开发基础(第一弹:创建表和创建约束)
- Oracle PL/SQL开发基础(第三十一弹:自定义异常)
- Oracle PL/SQL开发基础(第二十九弹:异常处理简介)
- Oracle PL/SQL开发基础(第三十三弹:EXCEPTION_INIT)
- Oracle PL/SQL开发基础(第九弹:多表连接查询)
- Oracle基础知识:在PL/SQL中修改ORACLE的字段顺序
- Oracle PL/SQL开发基础(第二十一弹:基本函数)
- Oracle PL/SQL开发基础(第三十四弹:RAISE_APPLICATION_ERROR)
- Oracle PL/SQL开发基础(第二弹:使用数据字典视图查看表约束)
- Oracle PL/SQL开发基础(第十五弹:同义词)
- Oracle PL/SQL开发基础(第十一弹:表集合操作)
- Oracle PL/SQL开发基础(第十七弹:集合类型)
- Oracle PL/SQL开发基础(第二十八弹:使用锁定)
- Oracle PL/SQL开发基础(第三十二弹:SQLCODE和SQLERRM)
- Oracle PL/SQL开发基础(第十六弹:记录类型)