- 1、本文档共110页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
11讲数据完整
第11讲 数据完整性 主讲人:胡秀芳 南通大学地理科学学院 hxf@ntu.edu.cn 主要内容: 1 数据完整性概述 2 使用约束实施数据的完整性 3 规则 4 默认 5 使用自动编号IDENTITY 6 总结 数据的完整性指数据库中数据的一致性与正确性。在SQL Server 2000中,可以通过约束、默认、规则、触发器等来达到保证数据完整性的目的。 本讲介绍如何通过约束、默认与规则实现数据的完整性。 1 数据完整性概述 1.1 数据完整性的含义 数值的完整性,指数据类型与取值的正确性。 表内数据不相互矛盾。 表间数据不相互矛盾,指数据的关联性不被破坏。 1.2 数据完整性有不同的分类方法 1.2.1按照数据完整性的功能将其分为 实体完整性 值域完整性 引用完整性 用户定义的完整性 实体完整性 要求表中每一条记录(每一行数据)是惟一的,即它必须至少拥有一个惟一标识以区分不同的数据行。 实现方法:主键约束PRIMARY KEY、惟一性约束UNIQUE、惟一索引UNIQUE INDEX、标识IDENTITY等 值域完整性 限定表中输入数据的数据类型与取值范围。 实现方法:默认值约束DEFAULT或默认对象、核查约束CHECK、外键约束FOREIGN KEY、规则RULE 、数据类型、非空性约束NOT NULL等。 引用完整性 指对数据库进行添加、删除、修改数据时,要维护表间数据的一致性。 实现方法:外键约束FOREIGN KEY、核查约束CHECK、触发器TRIGGER、存储过程PROCEDURE。 用户定义的完整性 用于实现用户特殊要求的数据规则或格式。 实现方法:默认值DEFAULT、核查约束CHECK、规则RULE 等。 1.2.2按照在数据库中实现数据完整性的作用级别 对象级 作用范围是数据库的某个表对象,是在定义表的同时定义的,删除表则失去作用,如约束。 总体级 是作为数据库的对象单独定义的,因此单独存在于数据库中,需要时可以绑定到数据库的表或用户定义的数据类型中,如默认对象、规则。 1.2.3 按照数据完整性的实施方法包括: 约束 默认规则 触发器 存储过程等 2 使用约束 约束用于实现表内数据的完整性,属于对象级。 SQL Server 支持的约束有如下6种: 非空约束NOT NULL 主键约束PRIMARY KEY 惟一约束UNIQUE 核查约束CHECK 外键约束 FOREIGN KEY 默认值约束DEFAULT 约束的定义:可以在创建表时定义,也可以在修改表时定义(即向已有的表中添加约束),但同一个数据库中不同约束的名称不能相同。 约束的作用范围 在定义列时定义的约束,仅作用于本列,称为列级约束; 表中单独定义的约束,称为表级约束。 表级约束的声明与列的定义无关,当一个约束作用于一个以上的列时,必须使用表级约束。 2.1 主键约束PRIMARY KEY 通常在表中将一个列或列组合的数据设置成具有各不相同的值,以便能惟一地标识表中的每一行。 这样的一列或多列称为表的主键,通过它可强制实现表的实体完整性,消除表的冗余数据。 主键具有如下特性: 不重复性 非空性 惟一性 2.1.1 创建表时定义主键约束 (1)定义列级主键 命令格式: CREATE TABLE table_name ( column_name data_type [ DEFAULT default_expression ] | [ IDENTITY [ ( seed ,increment ) ] ] [ [ CONSTRAINT constraint_name ] PRIMARY KEY [ CLUSTERED | NONCLUSTERED ] ] [,... n]) 命令说明: DEFAULT为默认值约束的关键字,用于指定其后的default_expression为默认值表达式。 IDENTITY [ ( seed,increment)]表示该列为标识列或称自动编号列。 CONSTRAINT constraint_name 为可选项,关键字CONSTRAINT用于指定其后面的约束名称constraint_name。如省略本选项,则系统自动给出一个约束名。建议选择约束名以
您可能关注的文档
最近下载
- 作业设计研讨活动记录.doc
- 2025国家电投校园招聘笔试备考题库及答案解析.docx
- 2021-2022学年五年级上学期综合实践活动(劳动教育)第6课巧做糖画教案.docx
- 创业意识与创业技巧:了解企业登记注册流程.pptx
- 山东省淄博市2023年高一上学期《英语》期中试卷与参考答案.pdf
- 大学生职业规划大赛成长赛道 (修订).pptx
- 2018重庆市建设工程混凝土与砂浆配合比表.pdf
- WhyNothingWorks.doc VIP
- 住院医师规范化培训基地标准(2022年版)--皮肤科专业基地细则.docx
- JB∕T 2436.2-2020 导线用铜压接端头 第2部分:10mm2~300mm2导线用铜压接端头.pdf
文档评论(0)