设计数据完整性.pptx
第十五章
设计数据完整性
主要内容1、数据完整性的基础知识2、使用约束实施数据完整性3、使用默认值实施数据完整性4、使用规则实施数据完整性
SQL数据库不只是存储数据,还必须保证所存储的数据是正确的。必须提供一种机制,来检查数据是否满足规定的条件,以保证数据正确,避免不合语义的错误数据的输入和输出。SQL提供了大量的完整性约束,保证数据库表中数据的完整性。本章将主要讨论各种类型的约束及其在SQL数据库中的应用
数据完整性基础数据完整性:是衡量数据库中数据质量好坏的一种标志,是确保数据库中数据一致、正确以及符合企业规则的一种思想,是使无序的数据条理化,确保正确的数据存放在正确位置的一种手段。
完整性要求的数据具有以下3个特点:数据的值正确无误.数据类型要正确,数据的值必须存在于正确的范围内.数据的存在必须确保同一表格数据之间的和谐关系例如:一个表中不允许有相同的实体存在.数据的存在必须确保不同表格数据之间的和谐关系主键和外键的关系,外键所在表中的值必须在主键所在表中存在,如果不存在就失去意义.
14.1完整性约束简介完整性约束简称约束,是关系数据库中的对象,用以存放插入到一个表某一列数据的规则。在SQL中有多种不同类型的约束。
用户定义的完整性:不同的关系数据库系统根据其应用环境的不同,往往还需要一些特殊的约束条件。用户定义的完整性即是针对某个特定关系数据库的约束条件,它反映某一具体应用必须满足的语义要求。06域完整性:是指表中的列必须满足某种特定的数据类型或约束,其中约束又包括取值范围、精度等规定。04约束是用来确保数据的准确性和一致性。数据的完整性就是对数据的准确性和一致性的一种保证。数据完整性(DataIntegrity)是指数据的精确(Accuracy)和可靠性(Reliability)。01实体完整性:规定表的每一行在表中是惟一的实体。03参照完整性:是指两个表的主关键字和外关键字的数据应一致,保证了表之间的数据的一致性,防止了数据丢失或无意义的数据在数据库中扩散。05数据完整性分为以下四类。0214.1.1数据的完整性
0504020301实体完整性:Primarykey、unique、unique、identitycolumn值域完整性:default、check、Foreignkey、notnull引用(参照)完整性:Foreignkey、check、triggers、procedure自定义完整性:rule、triggers、procedure、createtable中的所有列级和表级约束实施数据完整性的途径
PrimarykeyForeignkeyUniqueCheckNullable(可否为空)约束Cascade(级联引用一致性约束)一、使用约束实施数据完整性
Primarykey约束利用表中的一列或多列数据来惟一地标识一行数据。01当在一个已经存放了数据的表上增加主键时,SQLServer会自动对表中的数据进行检查,以确保这些数据能够满足主键约束的要求:不存在为null的值不存在重复的值02Primarykey约束
01创建表格时定义约束02在已有数据但没有重复值的列上添加约束03修改或删除表上已定义的约束创建约束的三种方式:
注意:修改已经建立的主键时,只能先删除原来的主键再重新建立一个新的主键.当一列受到主键约束时,不允许修改该列的长度.当主键被别的表中的外键所引用时,不允许删除主键.除非首先将引用主键的外键删除.12
[CLUSTERED|NONCLUSTERED][,…n][CLUSTERED|NONCLUSTERED][,…n](列名数据类型[constraint约束名])[constraint约束名]primarykeycreatetable表名primarykey定义Primarykey的语法
01usewanzheng02go03createtabletest204(05bianhaosmallint06constraintpk_id07primarykey,08gongziintnotnull09)【例2】创建表时,为主键约束命名
添加Primarykey的语法:altertable表名add[constraint约束名]primarykey[CLUSTERED|NONCLUSTERED](列名[,…n])
altertabletest1addconstraintpk_id1primarykey(bianhao)【例6】添加主键(续)
【例4】使用系统存储过程可以浏览指定表上的主键信