04设计数据完整性.ppt

  1. 1、本文档共70页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 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])

您可能关注的文档

文档评论(0)

wuhuaiyu002 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档