第5章 完整性约束定义.ppt
《第5章 完整性约束定义.ppt》由会员分享,可在线阅读,更多相关《第5章 完整性约束定义.ppt(30页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、5.4 数据完整性的概念与实施方法5.4.1 5.4.1 数据完整性概念数据完整性概念n数据完整性是指数据的正确性、完备性和一致性,是衡量数据库质量好坏的重要标准。n在用INSERT、DELETE、UPDATE语句修改数据库内容时,数据的完整性可能会遭到破坏。可能会存在下列情况:无效的数据被添加到数据库的表中。如:将学生考试成绩输入成负数;nSQL Server提供了对数据库中表、列实施数据完整性的方法。对表进行设计数据完整性有两个重要内容:标识列的有效值和确定如何强制列中的数据完整性。11.1.域完整性域完整性n域完整性是指一个列的输入有效性,是否允许空值。强制域完整性的方法有:限制类型(通
2、过设定列的数据类型)、格式(通过CHECK约束和规则)或可能值的范围(通过 FOREIGN KEY 约束、CHECK 约束、DEFAULT定义、NOT NULL定义和规则)。2.2.实体完整性实体完整性n实体完整性是指保证表中所有的行唯一。实体完整性要求表中的所有行都有一个唯一标识符。这个唯一标识符可能是一列,也可能是几列的组合,称之为主键。也就是说,表中主键在所有行上必须取值唯一。强制实体完整性的方法有:索引、UNIQUE约束、PRIMARY KEY约束或 IDENTITY属性。3.3.参照完整性参照完整性n参照完整性也叫引用完整性。参照完整性总是保证主关键字(被引用表)和外部关键字(引用表
3、)之间的参照关系。它涉及两个或两个以上表数据的一致性维护。25.4.2 5.4.2 数据完整性实施方法数据完整性实施方法1.1.声明型数据完整性声明型数据完整性n声明型数据完整性一般在对象创建时定义,由SQL Server强制实施,通常使用约束、缺省值和规则来实现使用约束、缺省值和规则来实现。实现基本数据完整性的首选方法是使用声明型数据完整性。n声明型数据完整性作为数据库对象说明的一部分在语法中实现,在CREATE TABLE和ALTER TABLE定义中使用CONSTRAINT、DEFAULT等语句限制表中的值。使用这种方法实现数据完整性简单且不易出错,系统直接将实现数据完整性的要求定义在表
4、和列上。2.2.过程型数据完整性过程型数据完整性n过程型数据完整性是指由某个过程引发而实施的数据完整性。一般先写出实施数据完整性的条件,再写出强制该条件所执行的用于保证数据完整性的脚本。通常由触发器和由触发器和存储过程存储过程实现。过程型数据完整性也可以在客户机和服务器上使用其它编程语言和工具实现。35.4.3 5.4.3 约束约束1.1.约束的定义和类型约束的定义和类型n约束是SQL Server提供的自动保持数据库完整性的一种方法。n列级约束:列级约束:列级约束是行定义的一部分,只能够应用在一列上。n表表级级约约束束:表级约束的定义独立于列的定义,可以应用在一个表中的多列上。n约束有六六种
5、种类类型型:非非空空约约束束、缺缺省省约约束束、检检查查约约束束、主主键键约约束束、唯一约束唯一约束、外键约束外键约束(参照约束)。n非空约束(非空约束(NOT NULLNOT NULL):表中的某些列必须存在有效值,不允许有空值出现。这是最简单的数据完整性约束,可在建表时将该列声明为NOT NULL即可。n缺省约束(缺省约束(DEFALUT CONSTRAINTSDEFALUT CONSTRAINTS):当向数据库中的表插入数据时,如果用户没有明确给出某列的值,SQL Server自动为该列输入指定值。4n检查约束(检查约束(CHECK CONSTRAINTSCHECK CONSTRAINT
6、S):限制插入列中的值的范围。n主键约束(主键约束(PRIMARY KEY CONSTRAINTSPRIMARY KEY CONSTRAINTS):要求主键的列上没有两行具有相同值,也没有空值。n唯一约束(唯一约束(UNIQUE CONSTRAINTSUNIQUE CONSTRAINTS):要求表中所有行在指定的列上没有完全相同的列值。n外键约束(外键约束(FROEIGN KEY CONSTRAINTSFROEIGN KEY CONSTRAINTS):要求正被插入或更新的列(外键)的新值,必须在被参照表(主表)的相应列(主键)中已经存在。5n不同的约束强制不同类型的数据完整性。表中 给出了两者
7、的对应关系。完整性类型完整性类型约束类型约束类型域完整性域完整性非空约束非空约束 DEFAULTDEFAULTCHECKCHECK实体完整性实体完整性PRIMARY KEYPRIMARY KEYUNIQUEUNIQUE参照完整性参照完整性FOREIGN KEYFOREIGN KEY62.2.使用使用T-SQLT-SQL语言创建、管理约束语言创建、管理约束(1)(1)使用使用CREATE TABLECREATE TABLE语句创建约束语句创建约束n使用使用CREATE TABLECREATE TABLE语句创建约束的一般语法如下:语句创建约束的一般语法如下:CREATE TABLECREATE
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 第5章 完整性约束定义 完整性 约束 定义
限制150内