参照完整性
参照完整性

CREATE TABLE 读者
(读者号 char(6) PRIMARY KEY, 姓名 varchar(20), 性别 c har(2),
读者类型ID char(6), 类型名称varchar(16), FOREIGN KEY(读者类型ID) REFERENCES读者类型(读者类型ID) )
数据库
王伟 清华大学出版社
9781765982 数据库应用 郑智浩 电子工业出版社
9781766770 数据库原理 王丽娟 清华大学出版社
•借阅表中插入一条新记录 •借阅表中修改一^ ISBN号 •图书表中删除一条记录 •图书表中修改—ISBN号
外码
、 Borrow关系
Reader BorrowDate
ALTER TABLE 借阅 ADD CONSTRAINT FK_图书号 FOREIGN KEY(图书 号) REFERENCES图书(图书号)
4.2.3参照完整性检查和违约处理
食可能破坏参照完整性的情况及违约处理
主码4
(TSBN)
9781267845
Book关系
BookName Editor
Press
整性规则自动进行检查并进行违约处理。
可能破坏参照完整性乍■ 插入元组
违约处理 ,
拒绝 /
可能破坏参照完整性 ■■ 修改外码值 删除元组 ■降可能破坏参照完整性
拒绝 拒绝/级联删除/设置空值
修改主码值 ■降可能破坏参照完整性
拒绝/级联修改/设置空值
默认策略
4.2.3参照完整性检查和违约处理
Pl创建参照表时显式定义违约处理策略-示例
CREATE TABLE 借阅 (读者号char(6), 图书号 varchar(15), 借阅日期datetime, 还书日期datetime,
第5章sql数据库完整性约束

5.2.4 默认值(DEFAULT)约束
默认约束是指在用户未提供某些列的数据时,数据库 系统为用户提供的默认值。从而简化应用程序代码和提高 系统性能。 表的每一列都可包含一个DEFAULT定义。可以修改或 删除现有的DEFAULT定义,但必须首先删除已有的 DEFAULT定义,然后通过新定义重新创建。 1.利用Management Studio定义(删除)default约束 步骤1:右键要建立default约束的表选择“修改”。 步骤2:在弹出的窗口中对应字段的“默认值或绑定”处 输入默认值。 步骤3:点击保存即可。
PRIMARY KEY约束在表中定义一个主键,唯一的标 识表中的行。一个表只能有一个PRIMARY KEY约束。
当向表中的现有列添加PRIMARY KEY约束时,SQL Server将检查列中现有的数据以确保现有数据遵从主键的 规则,即无空值、无重复值。 每个表都应有一个主键。主键可以是一列或列组合。
CREATE TABLE kc_new (5-4)
(课程号 CHAR(4) NOT NULL CONSTRAINT pk_kch1 PRIMARY KEY, 课程名 CHAR(16) NOT NULL CONSTRAINT ix_kcm1 UNIQUE,
学分 SMALLINT,
参照完整性的实现方法分析

在 管理 大量 、 久 、 持 一致 数 据 的数 据 库应 用 系
账相 符 、 一票 相 符等 就 是参 照 完整 性 的表 现 , 账 如
统 中 , 保数 据 有 价 值 而 不 致 成 为 一 堆 毫 无 意 义 确 的数 据垃圾 , 护 存 储 在 数 据 库 中数 据 的逻 辑 一 维 致性 , 就是 数 据完 整 性 . 如果 数 据库 应 用 系统 中没 有确 保数据 完 整 性 的逻 辑 , 可 能 由于 数 据 库 中 则 数据 的可 靠性 降低 而 使用 户 失 去使 用 这些 数据 的 信心 . 数据 完 整性 是数 据 库 的一 个 特征 , 是 保证 也 数据 库 中 的数 据 准确 有 效 、 防止 错 误 、 实现 商 业规 则 的一 种 重要 机 制 . 照 完 整 性 是 企 业 数 据 库 中 参 普遍 存在 的数 据 约 束 关 系 , 财 务 上 要 求 的账 一 如
V0 . 6 N . 1 1 0 3 S o.O 2 e 20
文 章 编 号 :0 6 3 X 2 ))3 0 1 3 10 —77 ((2 0 —0 3 —0 X
参 照 完 整 性 的 实 现 方 法 分析
王 杰文 李赫 男 , , 汪凤麟 陶 滔 ,
(. 1南华 大学 现代教 育技术 中心 , 湖南 衡 阳 4 10 ;. 华大学 计算 机科学与技术学 院 , 20 12南 湖南 衡 阳 4 10 ) 20 1
摘
要 : 照 完整性 的 实施 是 数据 库 应 用 系统设 计 的关键 之 一 . 多数 商 用 关 系数 据 参 大
库都提供 两种实施参照完整性 的方法. 声明外部关键字或定义触发器 . 文章重点分析
两种 方 法的 利弊 .
数据完整性

3.5 数据完整性在数据库中数据完整性是指保证数据正确的特性,一般包括实体完整性、域完整性、参照完整性。
一、实体完整性是保证表中记录唯一的特性。
即在一个表中,不能有重复的纪录。
候选关键字:如果一个字段的值或几个字段的值能够唯一标识表中的一条记录,这样的字段称为侯选关键字。
主关键字:在一个表中可能会有几个具有这种特性的字段或者字段的组合,这时从中选择一个作为主关键字。
在VFP中将主关键字称做主索引,将侯选关键字称为侯选索引。
实现方法:在VFP中利用主关键字(主索引)或候选关键字(候选索引)来保证表中记录的惟一性。
例1. 打开数据库“成绩管理”,为学生表中的“学号”字段建立主索引(升序)。
二、域完整性1.域:列的取值的范围(EG:数学中的定义域)域完整性:列的取值范围合理性我们以前在创建表的时候指定不同的数据类型和宽度来限制字段的取值类型和取值范围,但这些还远远不够。
我们需要进一步对列里能输入什么样的数据严格要求。
2.实现域完整性的方法:设置列的有效性规则,设置列的默认值⑴设置列的有效性规则例2. 设置“成绩管理”数据库中“学生”表中年龄字段的有效性规则:要求学生表中的年龄必须在15-22之间,否则就认为输入无效!并提示“年龄只能在15-22岁之间!”例3. 设置“学生”表中系部字段的有效性规则:要求系部列的取值必须是四个系之一,如果输入其他值就认为输入无效!并提示“该系部名不存在!”例4.设置“成绩”表中成绩的有效性规则为:成绩只能在0-100分之间,如果用户输入错误,则提示“成绩不在范围内!”⑵为列设置默认值例5.对“学籍”表进行修改,设置“入学日期”的默认值为2009-08-26,然后打开表,输入一条新记录,观察现象例6. 对“学生”表进行修改,设置“系部”列的默认值为基础部,然后打开表,使用Append命令输入一条新记录,观察现象三、参照完整性1.思考:⑴如果同学们在填学生表的时候将自己的班级名称写错了, 写成了一个学校中根本不存在的班级, 这样的结果肯定是错误的。
详解sql中的参照完整性(一对一,一对多,多对多)

详解sql中的参照完整性(⼀对⼀,⼀对多,多对多)⼀、参照完整性参照完整性指的就是多表之间的设计,主要使⽤外键约束。
多表设计: ⼀对多、多对多、⼀对⼀设计1.⼀对多关联主要语句:constraint cus_ord_fk foreign key (customer_id) REFERENCES customer(id)创建客户表——订单表⼀个客户可以订多份订单,每份订单只能有⼀个客户。
-- 关联(1对N)create table customer(id int PRIMARY KEY auto_increment,name varchar (20) not null,adress varchar (20) not null);create table orders(order_num varchar(20) PRIMARY KEY,price FLOAT not NULL,customer_id int, -- 进⾏和customer 关联的字段外键constraint cus_ord_fk foreign key (customer_id) REFERENCES customer(id));insert into customer(name,adress) values("zs","北京");insert into customer(name,adress) values("ls","上海");SELECT * from customer;INSERT INTO orders values("010",30.5,1);INSERT INTO orders values("011",60.5,2);INSERT INTO orders values("012",120.5,1);SELECT * from orders;notice: constraint: 约束的意思。
数据完整性培训资料

17
❖ 对字段的输入输出格式、默认数值、显示标题、 字段注释以及表文件长名、数据表的注释进行 设置
❖ 设置单字段的数据输入规则,控制和检查输入 到该字段中的数据是否满足指定的要求;称为 “字段级”有效性规则
❖ 设置“记录级”规则,控制和检验所输入的整 条记录是否符合要求;一般包含和涉及两个或 两个以上字段;又称为多字段有效性规则
❖ 来自保留行表的未匹配行会被保留,而那些 来自替换 NULL 的表中的行会由 NULL 替换。
10
❖ 在DEPTNO列上,Project 右连接 Department (Right join)
11
❖ 全外连接返回那些存在于右表但不存在于左 表的行,加上那些存在于左表但不存在于右 表的行,还有内连接的行。
❖ 在VFP中,参照完整性可以保证:
当父表中没有关联记录时,记录不得添加到子表 中
当改变父表的值而导致子表中出现孤立记录时, 父表的值不能被改变
当父表记录在子表中有匹配记录时,该父表记录 不能被删除
27
❖ 在VFP中,建立参照完整性必须先建立表之间的联系 ❖ 永久关系是在数据库中建立并保存在数据库中的数据表之
间的永久关系;不经删除,将永远存在 ❖ 永久关系只能通过“数据库设计器”进行设置、编辑和删
除 ❖ 建立永久关系的数据表之间有父表和子表的区别 ❖ 关联其它表的称为“父表”;被关联的表称为“子表”
❖ 建立永久关系前提条件:
数据表必须有意义相同的“公共字段” 事先均以该“公共字段”作为索引关键字分别建立索 28
在项目管理器中打开表,选中某一字段后就可以 在窗口底部的“说明”栏中显示注释信息。
23
❖ 设置“约束”性规则的目的是保证数据输入的有 效性和正确性;减少数据输入错误
VFP知识点总结(考试必备)

一、有效性规则和参照完整性1.有效性规则先选中要求设置的字段,(1)“规则”:逻辑型表达式即SQL格式表达式。
例:年龄是15-20:年龄>=15 and 年龄<=20(2)“信息”:字符型表达式,直接摘抄加“”(英文状态)(3)“默认值”:看选中的字段是什么类型2.参照完整性(1)判断一方(没有重复字段的表)和多方(有重复字段的表)(2)一方建主索引,多方建普通索引(3)由一方向多方扯一条线(4)清理数据库(数据库—清理数据库,如果遇到“文件正在使用暂不能发布pack命令,”此时close all,再重新以独占方式打开数据库再进行一次清理)(5)右键编辑参照完整性(两个永久性联系须一一设置其参照完整性)二、SQL语句1.格式:格式一:Select [top]字段1/字段2…… from表1,表2…. where连接条件and(or) 筛选条件{group by 某一字段 [haing count(字段)] } order by字段1 asc/desc, 字段2asc/desc…… into table表格式二:Select[top]字段1/字段2…… from表1 join 表2 join表3…. on连接条件(返回来写) where筛选条件 {group by 某一字段 [haing count(字段)] } order by字段1 asc/desc, 字段2 asc/desc…… into table表⑴.“字段1/字段2……”,根据题目要求,搜索什么字段写什么字段,若其中某一字段在表中没有则认定为是起的新名字,在该字段前加as,之后向函数avg(),sum(),max(),min(),count()。
⑵.“group by 某一字段 [haing count(字段)]”为难点。
考虑用不用group by,首先在草稿纸上或脑海生成题目要求的表,选取一个个例填写分析是否用得到group by,按什么分组。
数据库表设计的四条原则

数据库表设计的四条原则
一、完整性原则:
完整性原则,是指一个关系数据库描述的实体或事实的完整性,它规定一个属性的值必须存在,但不要求一定是有效的值。
它可以防止数据库中出现空值带来的记录不完整的现象,确保数据库记录的完整性。
二、唯一性原则:
唯一性原则,是指一个表中列(字段)的唯一性原则。
它规定一个属性不能在同一表中两个记录中出现重复值,以防止表中有相同记录造成交叉参照,造成数据库信息不一致。
三、实体完整性原则:
实体完整性原则是指,一个实体间的各属性之间的相互关系必须是完整的,也就是所有的属性都必须是可以被完整的表达出来的,不能出现有一个属性无法被完整表达出来的现象。
实体完整性原则主要是为了防止一组实体属性不能正确地表述实体间的相关关系,而且它能够保证数据库的准确性。
四、参照完整性原则:
参照完整性原则是指,一个表中的数据项之间的参照完整性必须被保证。
它要求数据表中的信息必须完整,而不是只有部分信息,以便能够完全反映出数据表中的记录之间的一一对应关系,同时也是为了防止某一记录在引用另一记录时出现某种异常情况,从而影响到数据的正确性和一致性。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
Database System
数据库系统概论Introduction to Database Systems
主讲人:吴岩河南理工大学
第四章 数据库的完整性
知 识 点
实体完整性规则
1
参照完整性规则
2
用户定义的完整性规则
3
4.2 参照完整性规则
参照完整性的含义
定义参照完整性
参照完整性检查和违约处理
4.2.1 参照完整性的含义
参照完整性规则
若属性(或属性组)F是基本关系R的外码,它与基本关系S的主
相对应(R和S不一定是不同的关系),则对于R中每个元组在F上码K
s
的值必须:
●或者等于空值(F的每个属性值均为空值);
●或者等于S中某个元组的主码值。
4.2.2 定义参照完整性
用REFERENCES 短语指明外码参照哪些表的主码 2 可在创建表时定义约束或向表中添加约束
3 用FOREIGN KEY 短语定义哪些列为外码 1
4.2.2 定义参照完整性
创建表时定义-语法格式
CREATE TABLE <表名>
(<列名> <数据类型> ,
…
FOREIGN KEY(<列名>) REFERENCES 被参照表名(<列名>)
)
4.2.2 定义参照完整性
创建表时定义-示例
读者(读者号,姓名,性别,读者类型ID,类型名称)
创建“读者”表时定义“读者类型ID”参照“读者类型”表中的“读者类型ID”:
CREATE TABLE 读者
(读者号 char(6) PRIMARY KEY,
姓名 varchar(20),
性别 char(2),
读者类型ID char(6),
类型名称varchar(16),
FOREIGN KEY(读者类型ID) REFERENCES 读者类型(读者类型ID)
)
4.2.2 定义参照完整性
向表中添加约束-语法格式
ALTER TABLE <表名>
ADD CONSTRAINT<约束名> FOREIGN KEY(<列名>)
REFERENCES被参照表名(<列名>)
4.2.2 定义参照完整性
向表中添加约束-示例
图书(图书号,书名,主编,出版社,单价)
借阅(读者号,图书号,借阅日期,还书日期)
在已经创建的“借阅”表中添加名称为FK_图书号的参照完整性约束:
ALTER TABLE 借阅
ADD CONSTRAINT FK_图书号 FOREIGN KEY(图书号)
REFERENCES 图书(图书号)
程丽
2018-4-13
4.2.3 参照完整性检查和违约处理
可能破坏参照完整性的情况及违约处理
ISBN BookName Editor Press 9781267845 9781678676
9781765980 9781766770
数据库 数据库系统
数据库应用 数据库原理 王伟 陈瑾
郑智浩 王丽娟 清华大学出版社
清华大学出版社 高等教育出版社
电子工业出版社 9781765982 ISBN Reader BorrowDate 张晨
2018-3-2
王明明 2018-3-3 程丽 2018-4-12 程丽
2018-4-12
9781267845 9781267845 9781765980 9781766772
9781766770 9781766771 Borrow 关系
Book 关系
主码
外码
•
借阅表中插入一条新记录 •借阅表中修改一个ISBN 号 •图书表中删除一条记录 •图书表中修改一个ISBN 号
4.2.3 参照完整性检查和违约处理
可能破坏参照完整性的情况及违约处理
被参照表(例如图书表)参照表(例如借阅表)违约处理
可能破坏参照完整性插入元组
可能破坏参照完整性修改外码值删除元组可能破坏参照完整性修改主码值可能破坏参照完整性
拒绝
拒绝
拒绝/级联删除/设置空值
拒绝/级联修改/设置空值
默认策略
4.2.3 参照完整性检查和违约处理 创建参照表时显式定义违约处理策略-示例 CREATE TABLE 借阅
(读者号 char(6) ,
图书号 varchar(15) ,
借阅日期 datetime ,
还书日期 datetime ,
Primary Key(读者号,图书号), Foreign key (读者号) References 读者(读者号) ON DELETE CASCADE ON UPDATE CASCADE , Foreign key (图书号) References 图书 (图书号) ON DELETE NO ACTION ON UPDATE CASCADE )
/*在表级定义实体完整性 /*在表级定义参照完整性 /*当删除读者表中元组时,级联删除借阅表中相应元组 /*当更新读者表中读者号时,级联更新借阅表中相应元组 /*当删除图书表中元组造成与借阅表不一致时,拒绝删除 /*当更新图书表中图书号时,级联更新借阅表中相应元组
●参照完整性规则要求外键属性取值为被参照
表中某主码的取值,或者为空值。
●参照完整性规则可用Foreign Key定义。
●当执行增、删、改等操作时,DBMS根据参照
完整性规则自动进行检查并进行违约处理。