日期:2011-03-21 00:21:00 来源:本站整理
<b>Oracle数据库数据对象解析(中)</b>[Oracle防范]
本文“<b>Oracle数据库数据对象解析(中)</b>[Oracle防范]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
完好性约束
完好性约束用于加强数据的完好性,Oracle供应了5种完好性约束:
Check
NOT NULL
Unique
Primary
Foreign key
完好性约束是一种法则,不占用任何数据库空间.完好性约束存在数据字典中,在履行SQL或PL/SQL期间利用.用户可以指明约束是启用的还是禁用的,当约束启用时,他加强了数据的完好性,不然,则反之,但约束始终存在于数据字典中.
禁用约束,利用ALTER语句
ALTER TABLE table_name DISABLE CONSTRAINT constraint_name; |
或
ALTER TABLE policies DISABLE CONSTRAINT chk_gender |
假如要重新启用约束:
ALTER TABLE policies ENABLE CONSTRAINT chk_gender |
删除约束
ALTER TABLE table_name DROP CONSTRAINT constraint_name |
或
ALTER TABLE policies DROP CONSTRAINT chk_gender; |
Check 约束
在数据列上Check 约束需求 一个特别的布尔条件大概将数据列设置成TRUE,至少一个数据列的值是NULL,Check约束用于加强表中数据内容的简单的商业法则.用户利用Check约束保证数据法则的一致性.Check约束可以触及该行同属Check约束的其他数据列但不能触及其他行或其他表,或调用函数SYSDATE,UID,USER,USERENV.假如用户的商业法则需求这类的数据查抄,那么可以利用触发器.Check约束不保护LOB数据范例的数据列和对象、嵌套表、VARRY、ref等.单一数据列可以有多个Check约束保护,一个Check约束可以保护多个数据列.
成立表的Check约束利用CREATE TABLE语句,更改表的约束利用ALTER TABLE语句.
语法:
CONSTRAINT [constraint_name] CHECK (condition); |
Check约束可以被成立或增添为一个表约束,当Check约束保护多个数据列时,必须利用表约束语法.约束名是可选的并且假如这个名字不存在,那么oracle将产生一个以SYS_开始的唯一的名字.
例:
CREATE TABLE policies (policy_id NUMBER, holder_name VARCHAR2(40), gender VARCHAR2(1) constraint chk_gender CHECK (gender in ('M','F'), marital_status VARCHAR2(1), date_of_birth DATE, constraint chk_marital CHECK (marital_status in('S','M','D','W')) ); |
NOT NULL约束
NOT NULL约束利用在单一的数据列上,并且他保护的数据列必必要有数据值.缺省情况下,ORACLE答应任何列都可以有NULL值.某些商业法则要求某数据列必必要有值,NOT NULL约束将确保该列的全部数据行都有值.
例:
CREATE TABLE policies (policy_id NUMBER, holder_name VARCHAR2(40) NOT NULL, gender VARCHAR2(1), marital_status VARCHAR2(1), date_of_birth DATE NOT NULL ); |
关于NOT NULL的ALTER TABLE语句与其他约束略微有点差别.
ALTER TABLE policies MODIFY holder_name NOT NULL |
以上是“<b>Oracle数据库数据对象解析(中)</b>[Oracle防范]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
本文地址: | 与您的QQ/BBS好友分享! |
评论内容只代表网友观点,与本站立场无关!
评论摘要(共 0 条,得分 0 分,平均 0 分)
查看完整评论