- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第10章 数据的完整性
第10章 数据的完整性 主讲教师 毛一梅 2010.01 一、数据完整性概述 数据库的完整性是指数据的正确性和相容性,它检查和控制的对象是不合语义的、不正确的数据,防止它们进入数据库; 而安全性控制的对象是非法的用户和非法的操作,防止他们对数据库中数据的进行非法存取。 数据完整性是保证数据质量的一种重要方法,是现代数据库系统的一个重要特征。SQL Server 2005提供了一系列的数据完整性方法和机制。 数据操作中存在的问题 问题1:不能确保同一表内数据间的相容性。 问题2:不能确保不同表之间数据的相容性。 问题3:不能保证数据值的正确性。 显然要保证数据库中数据的完整性,仅仅依靠操纵人员的认真负责是不够的,数据库管理系统自身应该提供一套完整的定义、检查和控制的机制。 二、数据完整性的实现 约束(Constraint) 规则(Rule) 触发器(Trigger) 存储过程(Stored Procedure) 标识列(Identity Column) 数据类型(Data Type) 索引(Index)等。 数据完整性的实现途径 1.实体完整性 实体完整性的实现途径主要包括Primary Key(主键约束)、Unique(唯一性约束)、Unique Inedx(唯一索引)和Identity Column(标识列)。 2.域完整性 域完整性的实现途径主要包括Default(默认值)、Check(检查约束)、Foreign Key(外键约束)、Data Type(数据类型)和Rule(规则)。 3.参照完整性 参照完整性的实现途径主要包括Foreign Key(外键约束)、Check(检查约束)、Triggers(触发器)和Stored Procedure(存储过程)。 4.用户定义完整性 用户定义完整性的实现途径主要包括Check(检查约束)、Rule(规则)、Triggers(触发器)和Stored Procedure(存储过程)等。 三、约束 Primary Key约束 Unique约束 Check约束 Foreign Key约束 Default定义 Not Null约束 1、Primary Key约束 PRIMARY KEY约束是通过定义表的主键来实现实体完整性约束的。 为了能唯一的表示表中的数据行,通常将某一列或多列的组合定义为主键。 一个表只能有一个主键,而且主键约束中的列不能为空值,且唯一地标识表中的每一行。 如果主键不止一列,则一列中的值可以重复,但主键定义的所有列的组合值必须唯一。 Primary Key约束的创建 方法一:在“对象资源管理器”窗口中,,右击相应的数据表,选择【修改】命令,在表设计器中,右击需要设置为主键的列名,选择“设置主键”命令。 方法二:在建表时加入命令 [CONSTRAINT constraint_name ] PRIMARY KEY [CLUSTERED | NONCLUSTERED] ( column_name[,…n] ) Primary Key约束的删除 方法一:右击已设置的主键属性,在弹出的快捷菜单中选择【移除主键】命令。 方法二:使用T-SQL语句删除约束,其语法格式如下: DROP CONSTRAINT constraint_name 应用实例 【例10-1】在TeachingData数据库中,在StuInfo中为了唯一的区别每个学生实体,防止出现两条完全相同的学生记录,需要设置学号(SID)字段为主键。为StuInfo表创建PRIMARY KEY约束。 【例10-3】用T-SQL语句将成绩表ScoreInfo中的SID和CID字段设置复合主键,并将该约束命名为PK_SC。 ALTER TABLE ScoreInfo ADD CONSTRAINT PK_SC PRIMARY KEY CLUSTERED(SID,CID) 【例10-4】用T-SQL语句删除成绩表(ScoreInfo)中的已创建的主键。 2、Unique约束 UNIQUE约束确保表中一列或多列的组合值具有唯一性,防止输入重复值,主要用于保证非主键列的实体完整性。 Unique约束的创建 方法一:在“对象资源管理器”窗口中,右击相应的数据表,选择【修改】命令,在表设计器中,右击需要建立UNIQUE约束的列名,在弹出的快捷菜单中选择【索引/键】命令,然后在【索引/键】中添加约束,并设置【是唯一的】为“是”,完成后【关闭】。 方法二:在建表时加入命令 [CONSTRAINT constraint_name ] UNIQUE [CLUSTERED | NONCLUSTERED] ( column_name[,…n] ) Unique约束的删除 方法一:打开【索引/键】对话框后,
文档评论(0)