- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第3章 完整性约束
* SQL中的完整性约束 完整性约束的目的是保证用户对数据库进行修改时不会破坏数据的一致性(防止对数据的意外破坏)。 注意:数据的完整性与安全性的概念区别。前者是为了防止数据库中存在不符合语义的数据(防止数据垃圾),后者是防止对数据的非法存取。 DBMS的完整性约束 数据库的完整性是指数据的正确性和相容性。DBMS必须提供一些功能来保证数据库中数据的完整性,也称其为完整性检查,即提供一定的机制来检查数据库中的数据是否满足规定的条件(称为完整性约束条件)。 1、完整性约束条件 NOT NULL 约束 缺省值 UNIQUE 约束 PRIMARY KEY 约束 FOREIGN KEY 约束 CHECK 约束 NOT NULL 约束 限定了表的某一列中必须有值; 缺省值 在数据录入时,若没有输入数据,数据库自动输入一个预先规定的值; UNIQUE 约束 该列的值在表中不能重复出现(可以有空值); PRIMARY KEY 约束 用来唯一标识表中的一行(不能有空值),必须是唯一的列(应选择一般不会改变、短的和数值型的列); CHECK 约束 根据逻辑表达式来限定值域; FOREIGN KEY 约束 用来约束两个表间的关系(也称引用完整性约束) 编号 姓名 年龄 职称 医生记录 病员记录 编号 姓名 主治医生姓名 外键 注意:Oracle/SQL Server规定,外键只能引用在引用表中Primary Key或Unique约束的列。 唯一性约束 2、DBMS中的完整性约束实现机制 1) 定义表的约束条件 SQL create table demo ( tno number(4,0) primary key, tname char(8) not null, sex char(2) check(sex in (‘男’,‘女’)), salary number(6,2) default(0), tcode number(4,0) unique, dept varchar2(200) ); create table father_t ( Cno integer primary key, Cname char(10) not null, Credit numeric(3,1) ); create table son_t ( st_no integer primary key, fk_cno integer, grade integer, foreign key(fk_cno) references father_t( Cno ) ); 2) 断言(Assertion) 一个断言就是一个谓词,表达了我们希望数据库总能满足的一个条件。 请看下页示例: create Table Course( Cno integer not null, Tno integer not null, Cname char(10) not null, credit numeric(3,1) not null, Primary key(cno,tno)); create table Teacher( Tno integer Primary Key, Tname char(6) not null, Title char(6), Dept char(10)); 问题:每学期上课教师的人数不高于教师总数的60% Create assertion sum-constraint check ( ( select count(distinct Tno) from course ) ( select count( * ) from teacher )*0.6 ) 断言是不与任何一个表相联系的约束。 3) 定义触发器(Trigger) 触发器是一种特殊的存储过程,它在插入、删除、修改特定表中的数据时,触发执行(由DBMS自动调用)。它能提供比数据库本身标准功能更精细、更复杂的数据控制能力。可用于数据库的安全性控制和完整性检查。 请看下页范例: create table Teacher( Tno integer Primary Key, Tname char(6) not null, Title char(6), Dept char(10)); insert into Teacher values (101,李华,讲师,计算机); create Table Course(
文档评论(0)