第7章保证数据完整性.ppt

上传人:本田雅阁 文档编号:2567207 上传时间:2019-04-09 格式:PPT 页数:19 大小:545.01KB
返回 下载 相关 举报
第7章保证数据完整性.ppt_第1页
第1页 / 共19页
第7章保证数据完整性.ppt_第2页
第2页 / 共19页
第7章保证数据完整性.ppt_第3页
第3页 / 共19页
第7章保证数据完整性.ppt_第4页
第4页 / 共19页
第7章保证数据完整性.ppt_第5页
第5页 / 共19页
点击查看更多>>
资源描述

《第7章保证数据完整性.ppt》由会员分享,可在线阅读,更多相关《第7章保证数据完整性.ppt(19页珍藏版)》请在三一文库上搜索。

1、第7章 保证数据完整性,学习目标,学会使用PRIMARY KEY(主键)约束、UNIQUE(唯一)约束保证表完整性;学会使用CHECK(检查)约束、DEFAULT(默认约束)、DEFAULT(默认值)、RULE(规则)保证列数据完整性;学会使用PRIMARY KEY(主键)约束、FOREIGN KEY(外键)约束保证表与表之间的参照完整性。,内容框架,约束概述,约束的作用:保证了数据的完整性 提问:数据完整性有几类? 约束的种类: PRIMARY KEY约束 FOREIGN KEY约束 UNIQUE约束 检查约束 DEFAULT约束,主键约束,主键约束 某列或几个列的组合,其值能唯一标识表中一

2、行 。 【问题】在表course列CouNo上设置主键约束,外键约束,外键约束 外键可由一个列或多个列的组合而成,用以实现两个表之间的数据联系。如果要创建两个表之间的联系,可以向其中一个表中添加一个列或多个列的组合,并且把这些列定义成这个表的外键,这些列中存放的是另一个表中的主键值。一个表可以同时包含有多个外键约束。 【问题】要保证class表中的系代码在表Department中存在,请创建外键,UNIQUE约束,UNIQUE约束要求列的值不能重复,同时允许列的值为空 【问题】为Student表创建基于Pwd列,名为UQ_Student的唯一约束 说明:一个表格可以创建多个UNIQUE约束,它

3、主要用于不是主键但又要求不能有重复值的列,Check约束,CHECK约束限制列数据的有效范围。在对约束的列值进行更新(如录入、修改)时系统自动检查列数据的有效性。 【问题】要求course表的列couno的值只允许三位数字,DEFAULT约束,如果用户没有为定义了DEFAULT约束的列输入数据,则由该约束提供默认的数据(避免空值的有效方法之一) 【问题】为StuCou表的State列建立DEFAULT约束,提供“报名”的默认值 说明:一个列只能建立一个DEFAULT约束,删除约束,格式: ALTER TABLE table_name DROP CONSTRAINT constraint_nam

4、e,默认值(default),默认值是一种独立存储的数据库对象,其作用和默认约束是一样的。在创建之后,可以用到表中的一列或多列上,也可以用到用户自定义的数据类型。 实现方法 先创建(create default),再绑定(sp_bindefault)到列或用户自定义数据类型,【问题】创建一个默认d_bm,默认值为报名。然后绑定到表StuCou的列state。 思考:默认值和默认约束有什么不同?,默认值(续),删除方法 先解除绑定(sp_unbindefault),再删除,默认值(续),【重要事项】 Management Studio已不再提供管理默认值的功能。后续版本的Microsoft SQ

5、L Server 将删除该功能。请避免在新的开发工作中使用该功能,并应着手修改当前还在使用该功能的应用程序。请使用ALTER TABLE 或 CREATE TABLE 语句定义DEFAULT约束。,规则(rule),规则(RULE)是保证数据完整性的方法之一。它的作用与CHECK约束类似,保证列数据的有效范围 先创建规则,再绑定到列或用户自定义数据类型上 先解除绑定,再删除规则 【练习】创建规则r_crt,内容是限制值在15之间。然后绑定到表Course的列Credit上,使学分限制在1到5之间。 思考: 规则和CHECK约束的区别,规则(rule),【重要事项】Management Stud

6、io已不再提供管理规则功能。后续版本的Microsoft SQL Server将删除 CREATE RULE。请避免在新的开发工作中使用 CREATE RULE,并计划修改当前使用它的应用程序。建议改为使用CHECK约束。CHECK约束需要使用 CREATE TABLE 或 ALTER TABLE 的语句进行定义。,标识列IDENTITY,在开发项目时,有时希望计算机能自动地生成标识列,标识列的种子(即初值)为1,增量为1,第一行数据的标识列值自动自动生成1,第2行数据标识列的值系统自动生成为:前一行的标识列值加上增量,即为2,不需要人工输入标识列的值。 标识列与主键约束、唯一键约束一样,能唯一标识表中的每一行,可以用来保证表的完整性。,本章小结,本章介绍了约束、默认值、规则。 应该掌握使用Management Studio和Transact-SQL语句来创建、删除这些数据库对象。,课后任务,独自完成课后实训,

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 其他


经营许可证编号:宁ICP备18001539号-1