Oracle PL/SQL开发基础(第三弹:修改表)

修改表列

新增表列

如:

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表中的数据并没有被删除,依然存在。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值