文档详情

第章数据完整性约束第讲.ppt

发布:2017-06-20约3.07千字共27页下载文档
文本预览下载声明
* 第 6 章 实 现 数 据 完 整 性 约 束 * 6.1 数据完整性基本概念 6.2 实现声明完整性 6.3 实现过程完整性 主要内容 数据的完整性是为了防止数据库中存在不符合语义的数据。 加在数据库数据之上的语义约束条件就是数据完整性约束条件。 这些约束条件作为表定义的一部分存储在数据库中。 DBMS检查数据是否满足完整性条件的机制就称为完整性检查。 数据完整性基本概念 关系模型中的数据完整性包括? 1.列级约束 对数据类型的约束 对数据格式的约束 对取值范围或取值集合的约束 对空值的约束 2.元组约束 元组中各个字段之间的联系的约束,如:开始日期小于结束日期。 3.关系约束 是若干元组之间、关系之间的联系的约束。 完整性约束条件的作用对象 实现数据完整性一般是在服务器端完成的,在服务器端实现数据完整性主要有两种方法: 一种是在定义表时声明数据完整性,称为声明完整性, 另一种是在服务器端编写触发器来实现,称为过程完整性。 在执行对数据的增、删、改操作时,数据库管理系统自动检查用户定义的完整性约束条件。 只有符合约束条件的操作才会被执行。 实现数据完整性的方法 1. PRIMARY KEY(主码)约束 每个表只能有一个PRIMARY KEY约束; 用PRIMARY KEY约束的列取值不能有重复,而且不允许有空值; 添加主码约束的语法格式: ALTER TABLE 表名 ADD [CONSTRAINT] 约束名 PRIMARY KEY (列名 [, … n]) 实现声明完整性 约束可以在创建表的同时创建,也可以在已有的表上创建约束(P91创建的2张表上添加约束)。 ALTER TABLE 雇员 ADD CONSTRAINT PK_EMP PRIMARY KEY (雇员编号) 例:对雇员表和工作表添加主码约束 ALTER TABLE 工作 ADD CONSTRAINT PK_JOB PRIMARY KEY (工作编号) 给工作表增加主码约束? 用于限制在一个列中不能有重复的值。 用在事实上具有惟一性的属性列上,比如每个人的身份证号码、驾驶证号码等均不能有重复值。 注意: 允许有一个空值; 在一个表中可以定义多个UNIQUE约束; 可以在一个列或多个列上定义UNIQUE约束。 UNIQUE约束 添加UNIQUE约束的语法格式为: ALTER TABLE 表名 ADD [CONSTRAINT] 约束名 UNIQUE(列名 [, … n] ) 例.为雇员表的“电话”列添加UNIQUE约束。 ALTER TABLE 雇员 ADD CONSTRAINT UK_SID UNIQUE(电话) 添加UNIQUE约束 实现引用(参照)完整性。 外码所引用的列必须是有PRIMARY KEY约束或UNIQUE约束的列。 添加FOREIGN KEY约束的语法格式为: ALTER TABLE 表名 ADD [CONSTRAINT] 约束名 FOREIGN KEY(列名) REFERENCES 引用表名(列名) 外码约束 例.为雇员表的工作编号添加外码引用约束。 ALTER TABLE 雇员 ADD CONSTRAINT FK_job_id FOREIGN KEY(工作编号) REFERENCES 工作(工作编号) 外码约束示例 用于提供列的默认值。 只有在向表中插入数据时才检查DEFAULT约束。 添加DEFAULT约束的语法格式为: ALTER TABLE 表名 ADD [CONSTRAINT] 约束名 DEFAULT 默认值 FOR 列名 例.定义雇员表的工资的默认值为10000。 ALTER TABLE 雇员 ADD CONSTRAINT DF_SALARY DEFAULT 10000 FOR 工资 DEFAULT约束 用于限制列的取值在指定的范围内,使数据库中存放的值都是有意义的。 系统在执行INSERT语句和UPDATE语句时自动检查CHECK约束。 CHECK约束可约束同一个表中多个列之间的取值关系。 添加CHECK约束的语法格式为: ALTER TABLE 表名 ADD [CONSTRAINT] 约束名 CHECK (逻辑表达式) CHECK约束 例1.限制雇员的工资必须大于等于200。 ALTER TABLE 雇员 ADD CONSTRAINT CHK_Salary CHECK ( 工资=200 ) 例2.限制工资表的最低工资小于等于最高工资。 ALTER TABLE 工作 ADD CONSTRAINT CHK_Job_Salary C
显示全部
相似文档