《完整性约束定义》PPT课件.ppt
《《完整性约束定义》PPT课件.ppt》由会员分享,可在线阅读,更多相关《《完整性约束定义》PPT课件.ppt(30页珍藏版)》请在装配图网上搜索。
1,5.4数据完整性的概念与实施方法,5.4.1数据完整性概念数据完整性是指数据的正确性、完备性和一致性,是衡量数据库质量好坏的重要标准。在用INSERT、DELETE、UPDATE语句修改数据库内容时,数据的完整性可能会遭到破坏。可能会存在下列情况:无效的数据被添加到数据库的表中。如:将学生考试成绩输入成负数;SQLServer提供了对数据库中表、列实施数据完整性的方法。对表进行设计数据完整性有两个重要内容:标识列的有效值和确定如何强制列中的数据完整性。,2,1.域完整性域完整性是指一个列的输入有效性,是否允许空值。强制域完整性的方法有:限制类型(通过设定列的数据类型)、格式(通过CHECK约束和规则)或可能值的范围(通过FOREIGNKEY约束、CHECK约束、DEFAULT定义、NOTNULL定义和规则)。2.实体完整性实体完整性是指保证表中所有的行唯一。实体完整性要求表中的所有行都有一个唯一标识符。这个唯一标识符可能是一列,也可能是几列的组合,称之为主键。也就是说,表中主键在所有行上必须取值唯一。强制实体完整性的方法有:索引、UNIQUE约束、PRIMARYKEY约束或IDENTITY属性。3.参照完整性参照完整性也叫引用完整性。参照完整性总是保证主关键字(被引用表)和外部关键字(引用表)之间的参照关系。它涉及两个或两个以上表数据的一致性维护。,3,5.4.2数据完整性实施方法1.声明型数据完整性声明型数据完整性一般在对象创建时定义,由SQLServer强制实施,通常使用约束、缺省值和规则来实现。实现基本数据完整性的首选方法是使用声明型数据完整性。声明型数据完整性作为数据库对象说明的一部分在语法中实现,在CREATETABLE和ALTERTABLE定义中使用CONSTRAINT、DEFAULT等语句限制表中的值。使用这种方法实现数据完整性简单且不易出错,系统直接将实现数据完整性的要求定义在表和列上。2.过程型数据完整性过程型数据完整性是指由某个过程引发而实施的数据完整性。一般先写出实施数据完整性的条件,再写出强制该条件所执行的用于保证数据完整性的脚本。通常由触发器和存储过程实现。过程型数据完整性也可以在客户机和服务器上使用其它编程语言和工具实现。,4,5.4.3约束1.约束的定义和类型约束是SQLServer提供的自动保持数据库完整性的一种方法。列级约束:列级约束是行定义的一部分,只能够应用在一列上。表级约束:表级约束的定义独立于列的定义,可以应用在一个表中的多列上。约束有六种类型:非空约束、缺省约束、检查约束、主键约束、唯一约束、外键约束(参照约束)。非空约束(NOTNULL):表中的某些列必须存在有效值,不允许有空值出现。这是最简单的数据完整性约束,可在建表时将该列声明为NOTNULL即可。缺省约束(DEFALUTCONSTRAINTS):当向数据库中的表插入数据时,如果用户没有明确给出某列的值,SQLServer自动为该列输入指定值。,5,检查约束(CHECKCONSTRAINTS):限制插入列中的值的范围。主键约束(PRIMARYKEYCONSTRAINTS):要求主键的列上没有两行具有相同值,也没有空值。唯一约束(UNIQUECONSTRAINTS):要求表中所有行在指定的列上没有完全相同的列值。外键约束(FROEIGNKEYCONSTRAINTS):要求正被插入或更新的列(外键)的新值,必须在被参照表(主表)的相应列(主键)中已经存在。,6,不同的约束强制不同类型的数据完整性。表中给出了两者的对应关系。,7,2.使用T-SQL语言创建、管理约束(1)使用CREATETABLE语句创建约束使用CREATETABLE语句创建约束的一般语法如下:CREATETABLEtable_name(column_namedata_typeCONSTRAINTconstraint_namePRIMARYKEYCLUSTERED|NONCLUSTERED|UNIQUECLUSTERED|NONCLUSTERED|FOREIGNKEYREFERENCESref_table(ref_column)|DEFAULTconstant_expression|CHECK(logical_expression),.n),8,其中:table_name:创建约束所在的表的名称。column_name:列名。data_type:数据类型。constraint_name:约束名。在创建、修改、实现约束时注意以下几点:可以在已有的表上创建、修改、删除约束,而不必删除并重建表。可以在应用程序中创建错误检查逻辑,测试是否违反约束。在给表添加约束时,SQL将验证表中已有数据是否满足正在添加的约束。,9,缺省约束缺省约束是指当向数据库中的表插入数据时,如果用户没有明确给出某列的值时,SQLServer自动为该列输入的值,缺省约束用于实现域的完整性。创建DEFAULT约束时应考虑以下因素:DEFAULT约束只能用于INSERT语句不能用于具有IDENTITY属性的列每列只能有一个DEFAULT约束【例1】为数据库JWGL中表teacher的SEX(性别)字段创建一个缺省约束,缺省值为1(男)USEJWGLGOALTERTABLEteacherADDCONSTRAINTdefault_sexDEFAULT1FORSEX,10,检查约束检查约束用来指定某列可取值的清单、可取值的集合或可取值的范围。检查约束主要用于实现域完整性。创建CHECK约束时应考虑以下因素:当向数据库中的表执行插入或更新操作时,检查插入的新列值是否满足CHECK约束条件不能在具有IDENTITY属性,或具有timestamp或uniqueidentifier数据类型的列上放置CHECK约束CHECK条件不能含有子查询【例2】为数据库JWGL中表student_course的GRADE(成绩)字段创建一个检查约束,使得GRADE的值在0-100之间。USEJWGLGOALTERTABLEstudent_courseADDCONSTRAINTcheck_gradeCHECK(grade=0andgrade=0andgrade=100GOsp_bindrulegrade_rule,student_course.gradeGOsp_unbindrulestudent_course.gradeGOdroprulegrade_rule,29,5.4.6使用标识列1.标识列的定义IDENTITY属性使得某一列的取值是基于上一行的列值和为该列定义的步长自动生成的。IDENTITY列的值可以唯一地标识表中的一行,可以用于实现实体完整性。有关DENTITY列属性的特点及定义DENTITY列时的注意事项,本章第一节已经介绍。2.用T-SQL语言定义标识列定义标识列的语法:ALETRTABLEtable_nameADDcolumn_namedata_typeIDENTITY(seed,increment),30,table_name:要添加标识列的表名。column_name:要添加的标识列的名称。data_type:要添加的标识列的数据类型。Seed:标识列的种子值。Increment:标识列的步长。【例9】给表class增加一个标识列class_no,种子值:1,步长:1。USEJWGLGOALTERTABLEclassADDclass_nointIDENTITY(1,1)3.用企业管理器定义标识列使用企业管理器定义标识列的方法在已经介绍。,本章首页,- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 完整性约束定义 完整性 约束 定义 PPT 课件
装配图网所有资源均是用户自行上传分享,仅供网友学习交流,未经上传用户书面授权,请勿作他用。
关于本文