- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
除此之外,还可以通过定义触发器来实现其他完整性规则。用触发器可定义很复杂的完整性约束条件。 一旦某一用户定义了一个完整性约束条件检查的触发器,任何用户对该数据的增、删、改操作均由服务器自动激活相应的触发器,在核心层进行集中的完整性控制。 12.3 完整性约束命名子句 SQL3主张显式命名所有的约束。约束可以命名,以便引用。约束的命名使用保留字CONSTRAINT。 CONSTRAINT [ PRIMARY KEY短语 |FOREIGN KEY短语 |UNIQUE |CHECK短语] 1. CONSTRAINT 约束命名 例12.8 建立学生登记表Student,要求学号在90000~99999之间,姓名不能取空值,年龄小于30,性别只能是“男”或“女”。 CREATE TABLE Student Sno CHAR 5 CONSTRAINT C1 CHECK Sno BETWEEN 90000 AND 99999 , Sname CHAR 20 CONSTRAINT C2 NOT NULL, Sage NUMBER 3 CONSTRAINT C3 CHECK Sage 30 , Ssex CHAR 2 CONSTRAINT C4 CHECK Ssex IN ‘男’,‘女’ , CONSTRAINT StudentKey PRIMARY KEY Sno ; 在Student表上建立了5个约束条件,包括主码约束(命名为StudentKey)以及C1、C2、C3、C4四个列级约束。 使用ALTER TABLE语句修改表中的完整性约束 2. 修改表中的完整性限制 例12.9 修改表Student中的约束条件,要求学号改为在900000~999999之间,年龄由小于30改为小于40。 可以先删除原来的约束条件,再增加新的约束条件 ALTER TABLE StudentDROP CONSTRAINT C1; ALTER TABLE StudentADD CONSTRAINT C1 CHECK Sno BETWEEN 900000 AND 999999 , ALTER TABLE StudentDROP CONSTRAINT C3; ALTER TABLE StudentADD CONSTRAINT C3 CHECK Sage 40 ; 12.4 ORACLE的完整性约束 Oracle在CREATE TABLE 语句中提供了PRIMARY KEY子句,供用户在建表时指定关系中的主关键字列。 当用户程序对主关键字列进行更新操作时,系统自动进行完整性检查。凡操作使主关键字值为空值或主关键字值在表中不唯一,系统拒绝此操作,从而保证了实体完整性。 1. 实体完整性 Oracle在CREATE TABLE 语句中提供了FOREIGN KEY子句,供用户在建表时定义关系中的外关键字列,提供REFERENCES子句指明这些外键相应于哪个表的主关键字,用ON DELETE子句指明在删除被参照关系的元组时,如何处理参照关系中相应的元组(三种选择CASCADE、RESTRICTED、SET NULL)。 2. 参照完整性 Oracle允许在CREATE TABLE 语句中定义下列完整性约束: 列值非空(NOT NULL短语); 列值唯一(UNIQUE短语) ; 检查列值是否满足一个布尔表达式(CHECK短语)。 3. 用户定义完整性 例12.10 建立职工表EMP,要求每个职工的应发工资不得超过3000元。应发工资实际上就是实发工资列Sal与扣除项Deduct之和。 CREATE TABLE EMP Eno NUMBER 4 Ename VARCHAR 10 , Job VARCHAR 8 , Sal NUMBER 7,2 , Deduct NUMBER 7,2 Deptno NUMBER 2 , CONSTRAINTS C1 CHECK Sal + Deduct 3000 ; CREATE TABLE DEPT Dno VAR 3 , Dname VARCHAR 9 CONSTRAINT U1 UNIQUE, Loc VARCHAR 10 , CONSTRAINT PK_DEPT PRIMARY KEY Dno ; 其中 CONSTRAINT U1 UNIQUE 表示约束名为U1,该约束要求Dname列值唯一。 例12.11 学生选课数据库表。 -- 建立系数据表DEPT 要求系名Dname列取值唯一,系编号Dno列为主码 例2:学生选课数据库表。 -- 建立学生情况数据表Stud
文档评论(0)