第5章 完整性约束定义.ppt
5.4 数据完整性的概念与实施方法5.4.1 5.4.1 数据完整性概念数据完整性概念n数据完整性是指数据的正确性、完备性和一致性,是衡量数据库质量好坏的重要标准。n在用INSERT、DELETE、UPDATE语句修改数据库内容时,数据的完整性可能会遭到破坏。可能会存在下列情况:无效的数据被添加到数据库的表中。如:将学生考试成绩输入成负数;nSQL Server提供了对数据库中表、列实施数据完整性的方法。对表进行设计数据完整性有两个重要内容:标识列的有效值和确定如何强制列中的数据完整性。11.1.域完整性域完整性n域完整性是指一个列的输入有效性,是否允许空值。强制域完整性的方法有:限制类型(通过设定列的数据类型)、格式(通过CHECK约束和规则)或可能值的范围(通过 FOREIGN KEY 约束、CHECK 约束、DEFAULT定义、NOT NULL定义和规则)。2.2.实体完整性实体完整性n实体完整性是指保证表中所有的行唯一。实体完整性要求表中的所有行都有一个唯一标识符。这个唯一标识符可能是一列,也可能是几列的组合,称之为主键。也就是说,表中主键在所有行上必须取值唯一。强制实体完整性的方法有:索引、UNIQUE约束、PRIMARY KEY约束或 IDENTITY属性。3.3.参照完整性参照完整性n参照完整性也叫引用完整性。参照完整性总是保证主关键字(被引用表)和外部关键字(引用表)之间的参照关系。它涉及两个或两个以上表数据的一致性维护。25.4.2 5.4.2 数据完整性实施方法数据完整性实施方法1.1.声明型数据完整性声明型数据完整性n声明型数据完整性一般在对象创建时定义,由SQL Server强制实施,通常使用约束、缺省值和规则来实现使用约束、缺省值和规则来实现。实现基本数据完整性的首选方法是使用声明型数据完整性。n声明型数据完整性作为数据库对象说明的一部分在语法中实现,在CREATE TABLE和ALTER TABLE定义中使用CONSTRAINT、DEFAULT等语句限制表中的值。使用这种方法实现数据完整性简单且不易出错,系统直接将实现数据完整性的要求定义在表和列上。2.2.过程型数据完整性过程型数据完整性n过程型数据完整性是指由某个过程引发而实施的数据完整性。一般先写出实施数据完整性的条件,再写出强制该条件所执行的用于保证数据完整性的脚本。通常由触发器和由触发器和存储过程存储过程实现。过程型数据完整性也可以在客户机和服务器上使用其它编程语言和工具实现。35.4.3 5.4.3 约束约束1.1.约束的定义和类型约束的定义和类型n约束是SQL Server提供的自动保持数据库完整性的一种方法。n列级约束:列级约束:列级约束是行定义的一部分,只能够应用在一列上。n表表级级约约束束:表级约束的定义独立于列的定义,可以应用在一个表中的多列上。n约束有六六种种类类型型:非非空空约约束束、缺缺省省约约束束、检检查查约约束束、主主键键约约束束、唯一约束唯一约束、外键约束外键约束(参照约束)。n非空约束(非空约束(NOT NULLNOT NULL):表中的某些列必须存在有效值,不允许有空值出现。这是最简单的数据完整性约束,可在建表时将该列声明为NOT NULL即可。n缺省约束(缺省约束(DEFALUT CONSTRAINTSDEFALUT CONSTRAINTS):当向数据库中的表插入数据时,如果用户没有明确给出某列的值,SQL Server自动为该列输入指定值。4n检查约束(检查约束(CHECK CONSTRAINTSCHECK CONSTRAINTS):限制插入列中的值的范围。n主键约束(主键约束(PRIMARY KEY CONSTRAINTSPRIMARY KEY CONSTRAINTS):要求主键的列上没有两行具有相同值,也没有空值。n唯一约束(唯一约束(UNIQUE CONSTRAINTSUNIQUE CONSTRAINTS):要求表中所有行在指定的列上没有完全相同的列值。n外键约束(外键约束(FROEIGN KEY CONSTRAINTSFROEIGN KEY CONSTRAINTS):要求正被插入或更新的列(外键)的新值,必须在被参照表(主表)的相应列(主键)中已经存在。5n不同的约束强制不同类型的数据完整性。表中 给出了两者的对应关系。完整性类型完整性类型约束类型约束类型域完整性域完整性非空约束非空约束 DEFAULTDEFAULTCHECKCHECK实体完整性实体完整性PRIMARY KEYPRIMARY KEYUNIQUEUNIQUE参照完整性参照完整性FOREIGN KEYFOREIGN KEY62.2.使用使用T-SQLT-SQL语言创建、管理约束语言创建、管理约束(1)(1)使用使用CREATE TABLECREATE TABLE语句创建约束语句创建约束n使用使用CREATE TABLECREATE TABLE语句创建约束的一般语法如下:语句创建约束的一般语法如下:CREATE TABLECREATE TABLE table_name table_name(column_name data_typecolumn_name data_typeCONSTRAINTCONSTRAINT constraint_name constraint_name PRIMARY KEYPRIMARY KEY CLUSTERED|NONCLUSTERED CLUSTERED|NONCLUSTERED|UNIQUE UNIQUE CLUSTERED|NONCLUSTEREDCLUSTERED|NONCLUSTERED|FOREIGN KEYFOREIGN KEY REFERENCES ref_table REFERENCES ref_table(ref_column)(ref_column)|DEFAULTDEFAULT constant_expression constant_expression|CHECKCHECK(logical_expression)(logical_expression),.n,.n)7其中其中:ntable_nametable_name:创建约束所在的表的名称。创建约束所在的表的名称。ncolumn_namecolumn_name:列名。列名。n data_typedata_type:数据类型。数据类型。nconstraint_nameconstraint_name:约束名。约束名。n在创建、修改、实现约束时注意以下几点:在创建、修改、实现约束时注意以下几点:可以在已有的表上创建、修改、删除约束,而不必删可以在已有的表上创建、修改、删除约束,而不必删除并重建表。除并重建表。可以在应用程序中创建错误检查逻辑,测试是否违反可以在应用程序中创建错误检查逻辑,测试是否违反约束。约束。在给表添加约束时,在给表添加约束时,SQLSQL将验证表中已有数据是否满将验证表中已有数据是否满足正在添加的约束。足正在添加的约束。8 缺省约束n缺省约束是指当向数据库中的表插入数据时,如果用户没有明确给出某列的值时,SQL Server自动为该列输入的值,缺省约束用于实现域的完整性缺省约束用于实现域的完整性。n创建DEFAULT约束时应考虑以下因素:qDEFAULT约束只能用于INSERT语句q不能用于具有IDENTITY属性的列q每列只能有一个DEFAULT约束【例例1 1】为数据库JWGL中表teacher的SEX(性别)字段创建一个缺省约束,缺省值为1(男)USE JWGLGOALTER TABLE teacherADD CONSTRAINT default_sex DEFAULT 1 FOR SEX9 检查约束检查约束n检查约束用来指定某列可取值的清单、可取值的集合或可取值的范围。检查约束主要用于实现域完整性。n创建创建CHECKCHECK约束时应考虑以下因素:约束时应考虑以下因素:q当向数据库中的表执行插入或更新操作时,检查插入的新列值是否满足CHECK约束条件q不能在具有IDENTITY属性,或具有timestamp或uniqueidentifier数据类型的列上放置CHECK约束qCHECK条件不能含有子查询【例例2 2】为数据库JWGL中表student_course 的GRADE(成绩)字段创建一个检查约束,使得GRADE的值在0-100之间。USE JWGLGOALTER TABLE student_courseADD CONSTRAINT check_grade CHECK (grade=0 and grade=0 and grade_rule as grade=0 and grade=100grade=100GOGOsp_bindrulesp_bindrule grade_rule,grade_rule,student_course.gradestudent_course.grade GOGOsp_unbindrulesp_unbindrule student_course.grade student_course.gradeGOGOdrop rule grade_ruledrop rule grade_rule285.4.6 5.4.6 使用标识列使用标识列1.1.标识列的定义标识列的定义 IDENTITY属性使得某一列的取值是基于上一行的列值和为该列定义的步长自动生成的。IDENTITY列的值可以唯一地标识表中的一行,可以用于实现实体完整性。n有关DENTITY列属性的特点及定义DENTITY列时的注意事项,本章第一节已经介绍。2.2.用用T-SQLT-SQL语言定义标识列语言定义标识列 定义标识列的语法:定义标识列的语法:ALETR TABLE table_name ADD column_name data_type IDENTITY(seed,increment)29n table_name:要添加标识列的表名。n column_name:要添加的标识列的名称。n data_type:要添加的标识列的数据类型。n Seed:标识列的种子值。n Increment:标识列的步长。【例9】给表class增加一个标识列class_no,种子值:1,步长:1。USE JWGLGOALTER TABLE classADD class_no int IDENTITY(1,1)3.3.用企业管理器定义标识列用企业管理器定义标识列n使用企业管理器定义标识列的方法在已经介绍。本章首页本章首页本章首页本章首页30