- 1、本文档共70页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第十五章设计数据完整性 主要内容 1、数据完整性的基础知识 2、使用约束实施数据完整性 3、使用默认值实施数据完整性 4、使用规则实施数据完整性 SQL数据库不只是存储数据,还必须保证所存储的数据是正确的。必须提供一种机制,来检查数据是否满足规定的条件,以保证数据正确,避免不合语义的错误数据的输入和输出。SQL提供了大量的完整性约束,保证数据库表中数据的完整性。本章将主要讨论各种类型的约束及其在SQL数据库中的应用 数据完整性基础 数据完整性:是衡量数据库中数据质量好坏的一种标志,是确保数据库中数据一致、正确以及符合企业规则的一种思想,是使无序的数据条理化,确保正确的数据存放在正确位置的一种手段。 完整性要求的数据具有以下3个特点: 1)数据的值正确无误.数据类型要正确,数据的值必须存在于正确的范围内. 2)数据的存在必须确保同一表格数据之间的和谐关系 例如:一个表中不允许有相同的实体存在. 3)数据的存在必须确保不同表格数据之间的和谐关系 主键和外键的关系,外键所在表中的值必须在主键所在表中存在,如果不存在就失去意义. 14.1 完整性约束简介 完整性约束简称约束,是关系数据库中的对象,用以存放插入到一个表某一列数据的规则。在SQL中有多种不同类型的约束。 14.1.1 数据的完整性 约束是用来确保数据的准确性和一致性。数据的完整性就是对数据的准确性和一致性的一种保证。数据完整性(Data Integrity)是指数据的精确(Accuracy)和可靠性(Reliability)。 数据完整性分为以下四类。 实体完整性:规定表的每一行在表中是惟一的实体。 域完整性:是指表中的列必须满足某种特定的数据类型或约束,其中约束又包括取值范围、精度等规定。 参照完整性:是指两个表的主关键字和外关键字的数据应一致,保证了表之间的数据的一致性,防止了数据丢失或无意义的数据在数据库中扩散。 用户定义的完整性:不同的关系数据库系统根据其应用环境的不同,往往还需要一些特殊的约束条件。用户定义的完整性即是针对某个特定关系数据库的约束条件,它反映某一具体应用必须满足的语义要求。 实施数据完整性的途径 实体完整性:Primary key 、unique 、unique 、identity column 值域完整性:default、check、Foreign key、not null 引用(参照)完整性:Foreign key 、check、triggers、procedure 自定义完整性:rule、 triggers、 procedure、 create table中的所有列级和表级约束 一、使用约束实施数据完整性 Primary key Foreign key Unique Check Nullable(可否为空)约束 Cascade(级联引用一致性约束) Primary key 约束 Primary key 约束利用表中的一列或多列数据来惟一地标识一行数据。 当在一个已经存放了数据的表上增加主键时,SQL Server会自动对表中的数据进行检查,以确保这些数据能够满足主键约束的要求: 1、不存在为null的值 2、不存在重复的值 创建约束的三种方式: 1、创建表格时定义约束 2、在已有数据但没有重复值的列上添加约束 3、修改或删除表上已定义的约束 注意: 1)修改已经建立的主键时,只能先删除原来的主键再重新建立一个新的主键.当一列受到主键约束时,不允许修改该列的长度. 2)当主键被别的表中的外键所引用时,不允许删除主键.除非首先将引用主键的外键删除. 定义Primary key 的语法 create table 表名 (列名 数据类型 [constraint 约束名] primary key [CLUSTERED | NONCLUSTERED] [,…n] [constraint 约束名] primary key [CLUSTERED | NONCLUSTERED] [,…n] ) 【例2】创建表时,为主键约束命名 use wanzheng go create table test2 ( bianhao smallint constraint pk_id primary key , gongzi int not null ) 添加Primary key 的语法: alter table 表名 add [constraint 约束名] primary key [CLUSTERED | NONCLUSTERED] (列名 [,…n])
您可能关注的文档
- 【优化方案】2014高考政治一轮复习课件:生活与哲学 第三单元第七课 唯物辩证法的联系观 新人教版必修4.ppt
- 3某项目经理部承接了一项道路.doc
- 【优化探究】2014年新课标高考总复习人教物理热学选修3-3-1.ppt
- 3-区域经济学的现实意义.ppt
- 【优化探究】2014年新课标高考总复习人教物理选修3-4-2-1光的折射全反射.doc
- 3生产区内的14个不准.ppt
- 3数据库设计与实现-高级ER图.ppt
- 【与名师对话】高考化学总复习(JS版)《1.1 物质的分类、转化及分散系》课件.ppt
- 03碎屑岩的成分.ppt
- 【语文】2010年高考试题上海卷(精校版).doc
- 《GB/T 32151.42-2024温室气体排放核算与报告要求 第42部分:铜冶炼企业》.pdf
- GB/T 32151.42-2024温室气体排放核算与报告要求 第42部分:铜冶炼企业.pdf
- GB/T 38048.6-2024表面清洁器具 第6部分:家用和类似用途湿式硬地面清洁器具 性能测试方法.pdf
- 中国国家标准 GB/T 38048.6-2024表面清洁器具 第6部分:家用和类似用途湿式硬地面清洁器具 性能测试方法.pdf
- 《GB/T 38048.6-2024表面清洁器具 第6部分:家用和类似用途湿式硬地面清洁器具 性能测试方法》.pdf
- 《GB/T 18238.2-2024网络安全技术 杂凑函数 第2部分:采用分组密码的杂凑函数》.pdf
- GB/T 18238.2-2024网络安全技术 杂凑函数 第2部分:采用分组密码的杂凑函数.pdf
- 《GB/T 17215.686-2024电测量数据交换 DLMS/COSEM组件 第86部分:社区网络高速PLCISO/IEC 12139-1配置》.pdf
- GB/T 13542.4-2024电气绝缘用薄膜 第4部分:聚酯薄膜.pdf
- 《GB/T 13542.4-2024电气绝缘用薄膜 第4部分:聚酯薄膜》.pdf
文档评论(0)