完整性约束定义

完整性约束定义

ID:37231081

大小:316.31 KB

页数:30页

时间:2019-05-11

完整性约束定义_第1页
完整性约束定义_第2页
完整性约束定义_第3页
完整性约束定义_第4页
完整性约束定义_第5页
资源描述:

《完整性约束定义》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、5.4数据完整性的概念与实施方法5.4.1数据完整性概念数据完整性是指数据的正确性、完备性和一致性,是衡量数据库质量好坏的重要标准。在用INSERT、DELETE、UPDATE语句修改数据库内容时,数据的完整性可能会遭到破坏。可能会存在下列情况:无效的数据被添加到数据库的表中。如:将学生考试成绩输入成负数;SQLServer提供了对数据库中表、列实施数据完整性的方法。对表进行设计数据完整性有两个重要内容:标识列的有效值和确定如何强制列中的数据完整性。11.域完整性域完整性是指一个列的输入有效性,是否允许空值。强制域完整性的方法有:限制类型(通过设定列的数据类型)、格式(通过CH

2、ECK约束和规则)或可能值的范围(通过FOREIGNKEY约束、CHECK约束、DEFAULT定义、NOTNULL定义和规则)。2.实体完整性实体完整性是指保证表中所有的行唯一。实体完整性要求表中的所有行都有一个唯一标识符。这个唯一标识符可能是一列,也可能是几列的组合,称之为主键。也就是说,表中主键在所有行上必须取值唯一。强制实体完整性的方法有:索引、UNIQUE约束、PRIMARYKEY约束或IDENTITY属性。3.参照完整性参照完整性也叫引用完整性。参照完整性总是保证主关键字(被引用表)和外部关键字(引用表)之间的参照关系。它涉及两个或两个以上表数据的一致性维护。25.4

3、.2数据完整性实施方法1.声明型数据完整性声明型数据完整性一般在对象创建时定义,由SQLServer强制实施,通常使用约束、缺省值和规则来实现。实现基本数据完整性的首选方法是使用声明型数据完整性。声明型数据完整性作为数据库对象说明的一部分在语法中实现,在CREATETABLE和ALTERTABLE定义中使用CONSTRAINT、DEFAULT等语句限制表中的值。使用这种方法实现数据完整性简单且不易出错,系统直接将实现数据完整性的要求定义在表和列上。2.过程型数据完整性过程型数据完整性是指由某个过程引发而实施的数据完整性。一般先写出实施数据完整性的条件,再写出强制该条件所执行的用

4、于保证数据完整性的脚本。通常由触发器和存储过程实现。过程型数据完整性也可以在客户机和服务器上使用其它编程语言和工具实现。35.4.3约束1.约束的定义和类型约束是SQLServer提供的自动保持数据库完整性的一种方法。列级约束:列级约束是行定义的一部分,只能够应用在一列上。表级约束:表级约束的定义独立于列的定义,可以应用在一个表中的多列上。约束有六种类型:非空约束、缺省约束、检查约束、主键约束、唯一约束、外键约束(参照约束)。非空约束(NOTNULL):表中的某些列必须存在有效值,不允许有空值出现。这是最简单的数据完整性约束,可在建表时将该列声明为NOTNULL即可。缺省约束(

5、DEFALUTCONSTRAINTS):当向数据库中的表插入数据时,如果用户没有明确给出某列的值,SQLServer自动为该列输入指定值。4检查约束(CHECKCONSTRAINTS):限制插入列中的值的范围。主键约束(PRIMARYKEYCONSTRAINTS):要求主键的列上没有两行具有相同值,也没有空值。唯一约束(UNIQUECONSTRAINTS):要求表中所有行在指定的列上没有完全相同的列值。外键约束(FROEIGNKEYCONSTRAINTS):要求正被插入或更新的列(外键)的新值,必须在被参照表(主表)的相应列(主键)中已经存在。5不同的约束强制不同类型的数据完整

6、性。表中给出了两者的对应关系。完整性类型约束类型域完整性非空约束DEFAULTCHECK实体完整性PRIMARYKEYUNIQUE参照完整性FOREIGNKEY62.使用T-SQL语言创建、管理约束(1)使用CREATETABLE语句创建约束使用CREATETABLE语句创建约束的一般语法如下:CREATETABLEtable_name(column_namedata_type[[CONSTRAINTconstraint_name]{PRIMARYKEY[CLUSTERED

7、NONCLUSTERED]

8、UNIQUE[CLUSTERED

9、NONCLUSTERED]

10、[FOREIG

11、NKEY]REFERENCESref_table[(ref_column)]

12、DEFAULTconstant_expression

13、CHECK(logical_expression)}][,...n])7其中:table_name:创建约束所在的表的名称。column_name:列名。data_type:数据类型。constraint_name:约束名。在创建、修改、实现约束时注意以下几点:①可以在已有的表上创建、修改、删除约束,而不必删除并重建表。②可以在应用程序中创建错误检查逻辑,测试是

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。