第章数据完整性约束第讲.pptVIP

  1. 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第章数据完整性约束第讲

* 第 6 章 实 现 数 据 完 整 性 约 束 * 6.1 数据完整性基本概念 6.2 实现声明完整性 6.3 实现过程完整性 主要内容 数据的完整性是为了防止数据库中存在不符合语义的数据。 加在数据库数据之上的语义约束条件就是数据完整性约束条件。 这些约束条件作为表定义的一部分存储在数据库中。 DBMS检查数据是否满足完整性条件的机制就称为完整性检查。 数据完整性基本概念 关系模型中的数据完整性包括? 1.列级约束 对数据类型的约束 对数据格式的约束 对取值范围或取值集合的约束 对空值的约束 2.元组约束 元组中各个字段之间的联系的约束,如:开始日期小于结束日期。 3.关系约束 是若干元组之间、关系之间的联系的约束。 完整性约束条件的作用对象 实现数据完整性一般是在服务器端完成的,在服务器端实现数据完整性主要有两种方法: 一种是在定义表时声明数据完整性,称为声明完整性, 另一种是在服务器端编写触发器来实现,称为过程完整性。 在执行对数据的增、删、改操作时,数据库管理系统自动检查用户定义的完整性约束条件。 只有符合约束条件的操作才会被执行。 实现数据完整性的方法 1. PRIMARY KEY(主码)约束 每个表只能有一个PRIMARY KEY约束; 用PRIMARY KEY约束的列取值不能有重复,而且不允许有空值; 添加主码约束的语法格式: ALTER TABLE 表名 ADD [CONSTRAINT] 约束名 PRIMARY KEY (列名 [, … n]) 实现声明完整性 约束可以在创建表的同时创建,也可以在已有的表上创建约束(P91创建的2张表上添加约束)。 ALTER TABLE 雇员 ADD CONSTRAINT PK_EMP PRIMARY KEY (雇员编号) 例:对雇员表和工作表添加主码约束 ALTER TABLE 工作 ADD CONSTRAINT PK_JOB PRIMARY KEY (工作编号) 给工作表增加主码约束? 用于限制在一个列中不能有重复的值。 用在事实上具有惟一性的属性列上,比如每个人的身份证号码、驾驶证号码等均不能有重复值。 注意: 允许有一个空值; 在一个表中可以定义多个UNIQUE约束; 可以在一个列或多个列上定义UNIQUE约束。 UNIQUE约束 添加UNIQUE约束的语法格式为: ALTER TABLE 表名 ADD [CONSTRAINT] 约束名 UNIQUE(列名 [, … n] ) 例.为雇员表的“电话”列添加UNIQUE约束。 ALTER TABLE 雇员 ADD CONSTRAINT UK_SID UNIQUE(电话) 添加UNIQUE约束 实现引用(参照)完整性。 外码所引用的列必须是有PRIMARY KEY约束或UNIQUE约束的列。 添加FOREIGN KEY约束的语法格式为: ALTER TABLE 表名 ADD [CONSTRAINT] 约束名 FOREIGN KEY(列名) REFERENCES 引用表名(列名) 外码约束 例.为雇员表的工作编号添加外码引用约束。 ALTER TABLE 雇员 ADD CONSTRAINT FK_job_id FOREIGN KEY(工作编号) REFERENCES 工作(工作编号) 外码约束示例 用于提供列的默认值。 只有在向表中插入数据时才检查DEFAULT约束。 添加DEFAULT约束的语法格式为: ALTER TABLE 表名 ADD [CONSTRAINT] 约束名 DEFAULT 默认值 FOR 列名 例.定义雇员表的工资的默认值为10000。 ALTER TABLE 雇员 ADD CONSTRAINT DF_SALARY DEFAULT 10000 FOR 工资 DEFAULT约束 用于限制列的取值在指定的范围内,使数据库中存放的值都是有意义的。 系统在执行INSERT语句和UPDATE语句时自动检查CHECK约束。 CHECK约束可约束同一个表中多个列之间的取值关系。 添加CHECK约束的语法格式为: ALTER TABLE 表名 ADD [CONSTRAINT] 约束名 CHECK (逻辑表达式) CHECK约束 例1.限制雇员的工资必须大于等于200。 ALTER TABLE 雇员 ADD CONSTRAINT CHK_Salary CHECK ( 工资=200 ) 例2.限制工资表的最低工资小于等于最高工资。 ALTER TABLE 工作 ADD CONSTRAINT CHK_Job_Salary C

文档评论(0)

docman126 + 关注
实名认证
文档贡献者

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

版权声明书
用户编号:7042123103000003

1亿VIP精品文档

相关文档