Oracle数据库的完整性约束和序列规则详解.doc

Oracle数据库的完整性约束和序列规则详解.doc

ID:57689448

大小:167.00 KB

页数:11页

时间:2020-09-01

Oracle数据库的完整性约束和序列规则详解.doc_第1页
Oracle数据库的完整性约束和序列规则详解.doc_第2页
Oracle数据库的完整性约束和序列规则详解.doc_第3页
Oracle数据库的完整性约束和序列规则详解.doc_第4页
Oracle数据库的完整性约束和序列规则详解.doc_第5页
资源描述:

《Oracle数据库的完整性约束和序列规则详解.doc》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、Oracle数据库的完整性约束规则详解完整性约束用于增强数据的完整性,Oracle提供了5种完整性约束:   Check   NOTNULL   Unique   Primary   Foreignkey完整性约束是一种规则,不占用任何数据库空间。完整性约束存在数据字典中,在执行SQL或PL/SQL期间使用。用户可以指明约束是启用的还是禁用的,当约束启用时,他增强了数据的完整性,否则,则反之,但约束始终存在于数据字典中。禁用约束,使用ALTER语句:ALTERTABLEtable_nameDISABLECONSTRAINTconstraint_name;或ALTERTABLEp

2、oliciesDISABLECONSTRAINTchk_gender如果要重新启用约束:ALTERTABLEpoliciesENABLECONSTRAINTchk_gender删除约束:ALTERTABLEtable_nameDROPCONSTRAINTconstraint_name或ALTERTABLEpoliciesDROPCONSTRAINTchk_gender;Check约束在数据列上Check约束需要一个特殊的布尔条件或者将数据列设置成TRUE,至少一个数据列的值是NULL,Check约束用于增强表中数据内容的简单的商业规则。用户使用Check约束保证数据规则的一致性

3、。Check约束可以涉及该行同属Check约束的其他数据列但不能涉及其他行或其他表,或调用函数SYSDATE,UID,USER,USERENV。如果用户的商业规则需要这类的数据检查,那么可以使用触发器。Check约束不保护LOB数据类型的数据列和对象、嵌套表、VARRY、ref等。单一数据列可以有多个Check约束保护,一个Check约束可以保护多个数据列。创建表的Check约束使用CREATETABLE语句,更改表的约束使用ALTERTABLE语句。语法:CONSTRAINT[constraint_name]CHECK(condition);Check约束可以被创建或增加为一

4、个表约束,当Check约束保护多个数据列时,必须使用表约束语法。约束名是可选的并且如果这个名字不存在,那么oracle将产生一个以SYS_开始的唯一的名字。例:CREATETABLEpolicies(policy_idNUMBER,holder_nameVARCHAR2(40),genderVARCHAR2(1)constraintchk_genderCHECK(genderin('M','F'),marital_statusVARCHAR2(1),date_of_birthDATE,constraintchk_maritalCHECK(marital_statusin('S'

5、,'M','D','W'))); NOTNULL约束NOTNULL约束应用在单一的数据列上,并且他保护的数据列必须要有数据值。缺省状况下,ORACLE允许任何列都可以有NULL值。某些商业规则要求某数据列必须要有值,NOTNULL约束将确保该列的所有数据行都有值。例:CREATETABLEpolicies(policy_idNUMBER,holder_nameVARCHAR2(40)NOTNULL,genderVARCHAR2(1),marital_statusVARCHAR2(1),date_of_birthDATENOTNULL);对于NOTNULL的ALTERTABLE语

6、句与其他约束稍微有点不同。ALTERTABLEpoliciesMODIFYholder_nameNOTNULL唯一性约束(Uniqueconstraint)唯一性约束可以保护表中多个数据列,保证在保护的数据列中任何两行的数据都不相同。唯一性约束与表一起创建,在唯一性约束创建后,可以使用ALTERTABLE语句修改。语法:column_namedata_typeCONSTRAINTconstraint_nameUNIQUE如果唯一性约束保护多个数据列,那么唯一性约束要作为表约束增加。语法如下:CONSTRAINTconstraint_name(column)UNIQUEUSING

7、INDEXTABLESPACE(tablespace_name)STORAGE(storedclause)唯一性约束由一个B-tree索引增强,所以可以在USING子串中为索引使用特殊特征,比如表空间或存储参数。CREATETABLE语句在创建唯一性约束的同时也给目标数据列建立了一个唯一的索引。CREATETABLEinsured_autos(policy_idNUMBERCONSTRAINTpk_policiesPRIMARYKEY,vinVARCHAR2(10),coverage_beg

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。