网站大量收购独家精品文档,联系QQ:2885784924

第5章 实现数据完整性约束(07-04).ppt

  1. 1、本文档共35页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第5章 数据完整性 5.1 数据完整性基本概念 5.2 实现声明完整性 5.3 实现过程完整性 5.1 数据完整性基本概念 数据的完整性是为了防止数据库中存在不符合语义的数据。 这些加在数据库数据之上的语义约束条件就是数据完整性约束条件。 这些约束条件作为表定义的一部分存储在数据库中。 DBMS检查数据是否满足完整性条件的机制就称为完整性检查。 5.1.1 完整性约束条件的作用对象 列级约束 对数据类型的约束 对数据格式的约束 对取值范围或取值集合的约束 对空值的约束 元组约束 元组中各个字段之间的联系的约束,如:开始日期小于结束日期。 关系约束 是若干元组之间、关系之间的联系的约束。 5.1.2 实现数据完整性的方法 一种是在定义表时声明数据完整性,称为声明完整性。 另一种是在服务器端编写触发器来实现,称为过程完整性。 DBMS 系统必须提供定义完整性条件的机制、提供完整性检查的方法和违约的处理 在执行对数据的增、删、改操作时,数据库管理系统自动检查用户定义的完整性约束条件。 假设有两个工作表: 雇员表 雇员(雇员编号,雇员名,工作编号,工资,电话) 工作表 工作(工作编号,最低工资,最高工资) 其中:雇员编号、工作编号分别是表的主码。 工作编号是雇员表的外码,引用工作表中的工作编号 5.2 实现声明完整性 1.主码约束 每个表只能有一个PRIMARY KEY约束; 用PRIMARY KEY约束的列取值不能有重复,而且不允许有空值; 可在数据表定义时体现,也可以根据需要添加。 添加主码约束的语法格式: ALTER TABLE 表名 ADD [ CONSTRAINT 约束名] PRIMARY KEY (列名 [, … n] ) 例:对雇员表和工作表添加主码约束 ALTER TABLE 雇员表 ADD CONSTRAINT PK_EMP PRIMARY KEY (雇员编号) ALTER TABLE 工作表 ADD CONSTRAINT PK_JOB PRIMARY KEY (工作编号) 2.UNIQUE约束 用于限制在一个列中不能有重复的值。 作用于具有惟一性的属性列上。 注意: 在一个表中可以定义多个UNIQUE约束; 可以在一个列或多个列上定义UNIQUE约束。 添加UNIQUE约束 添加UNIQUE约束的语法格式为: ALTER TABLE 表名 ADD [ CONSTRAINT 约束名] UNIQUE(列名 [, … n] ) 例.为雇员表的“电话”列添加UNIQUE约束。 ALTER TABLE 雇员表 ADD CONSTRAINT UK_SID UNIQUE(电话) 3.外码约束 实现引用完整性。 外码所引用的列须是有PRIMARY KEY约束的列。 添加FOREIGN KEY约束的语法格式为: ALTER TABLE 表名 ADD [ CONSTRAINT 约束名] FOREIGN KEY(列名) REFERENCES 引用表名(列名) 示例 例.为雇员表的工作编号添加外码引用约束。 ALTER TABLE 雇员 ADD CONSTRAINT FK_job_id FOREIGN KEY (工作编号)REFERENCES 工作表 (工作编号) 4.DEFAULT约束 用于提供列的默认值。 只有在向表中插入数据时才检查DEFAULT约束。 添加DEFAULT约束的语法格式为: ALTER TABLE 表名 ADD [ CONSTRAINT 约束名 ] DEFAULT 默认值 FOR 列名 例.定义雇员表的工资的默认值为1000。 ALTER TABLE 雇员 ADD CONSTRAINT DF_SALARY DEFAULT 1000 FOR 工资 5、CHECK约束 用于限制列的取值在指定的范围内,使数据库中存放的值都是有意义的。 系统在执行INSERT语句和UPDATE语句时自动检查CHECK约束。 CHECK约束可约束同一个表中多个列之间的取值关系。 添加CHECK约束的语法格式为: ALTER TABLE 表名 ADD [ CONSTRAINT 约束名 ] CHECK (逻辑表达式) 示例 例1.限制雇员的工资必须大于等于200。 ALTER TABLE 雇员 ADD CONSTRAINT CHK_Salary CHECK ( 工资 = 200 ) 例2.限制工资表的最低工资小于等于最高工资。 ALTER TABLE 工作 ADD CONSTRAINT CHK_Job_Salary CHECK( 最低工资 = 最高工资

文档评论(0)

yaocen + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档