第6篇 实现数据完整性约束.ppt

  1. 1、本文档共28页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据库原理与应用 高等院校计算机教材系列 第6章 实现数据完整性约束 6.1 数据完整性基本概念 6.2 实现声明完整性 6.3 实现过程完整性 6.1 数据完整性基本概念 数据的完整性是为了防止数据库中存在不符合语义的数据。 这些加在数据库数据之上的语义约束条件就是数据完整性约束条件。 这些约束条件作为表定义的一部分存储在数据库中。 DBMS检查数据是否满足完整性条件的机制就称为完整性检查。 6.1.1 完整性约束条件的作用对象 列级约束 对数据类型的约束 对数据格式的约束 对取值范围或取值集合的约束 对空值的约束 元组约束 元组中各个字段之间的联系的约束,如:开始日期小于结束日期。 关系约束 是若干元组之间、关系之间的联系的约束。 6.1.2 实现数据完整性的方法 一种是在定义表时声明数据完整性,称为声明完整性, 另一种是在服务器端编写触发器来实现,称为过程完整性。 在执行对数据的增、删、改操作时,数据库管理系统自动检查用户定义的完整性约束条件。 6.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约束或UNIQUE约束的列。 添加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 工资 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( 最低工资 = 最高工资 ) 6.3 实现过程完整性 过程完整性是指在服务器端通过编写实现约束的一段代码来实现数据完整性约束,这段代码就称为触发器。 触发器是用编程的方法实现复杂的商业规则,它可以实现一般的数据完整性约束实现不了的复杂的完整性约束。 6

文档评论(0)

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

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

1亿VIP精品文档

相关文档