参照完整性
参照完整性的实现方法分析

在 管理 大量 、 久 、 持 一致 数 据 的数 据 库应 用 系
账相 符 、 一票 相 符等 就 是参 照 完整 性 的表 现 , 账 如
统 中 , 保数 据 有 价 值 而 不 致 成 为 一 堆 毫 无 意 义 确 的数 据垃圾 , 护 存 储 在 数 据 库 中数 据 的逻 辑 一 维 致性 , 就是 数 据完 整 性 . 如果 数 据库 应 用 系统 中没 有确 保数据 完 整 性 的逻 辑 , 可 能 由于 数 据 库 中 则 数据 的可 靠性 降低 而 使用 户 失 去使 用 这些 数据 的 信心 . 数据 完 整性 是数 据 库 的一 个 特征 , 是 保证 也 数据 库 中 的数 据 准确 有 效 、 防止 错 误 、 实现 商 业规 则 的一 种 重要 机 制 . 照 完 整 性 是 企 业 数 据 库 中 参 普遍 存在 的数 据 约 束 关 系 , 财 务 上 要 求 的账 一 如
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
摘
要 : 照 完整性 的 实施 是 数据 库 应 用 系统设 计 的关键 之 一 . 多数 商 用 关 系数 据 参 大
库都提供 两种实施参照完整性 的方法. 声明外部关键字或定义触发器 . 文章重点分析
两种 方 法的 利弊 .
数据库表间的参照完整性_Visual FoxPro 程序设计_[共2页]
![数据库表间的参照完整性_Visual FoxPro 程序设计_[共2页]](https://img.taocdn.com/s3/m/9713d39de45c3b3566ec8b56.png)
52 的“字段”选项卡中包含有字段有效性规则。
可以先选择要定义有效性的字段,然后分别输入规则、信息及默认值。
【例4-9】以“学生管理”数据库的学生表为例,设性别字段有效性规则为只允许输入“男”或“女”字符,当输入的不是要求内容时,提示输入错误,性别字段的默认值为“男”。
在“规则”框中输入:性别="男" OR 性别="女"。
在“信息”框中输入:"性别输入错误!"。
在“默认值”框中输入:"男"。
“规则”是逻辑表达式,“信息”是字符串表达式,“默认值”的类型由字段的类型确定。
4.5.2 数据库表间的永久关系自由表之间可以建立临时关系,数据库表之间可以建立永久关系,永久关系保存在数据库中,不必在每次使用时重新建立。
在Visual FoxPro中,可以使用索引在数据库中建立表间的永久关系。
1.建立数据库表间的永久关系可以在数据库设计器中,选择想要关联的索引名,然后把它拖到相关表的索引名上。
在创建永久关系时,作为主表的索引必须使用主索引或候选索引,否则无法建立永久关系。
2.删除数据库表间的永久关系可以在数据库设计器中,单击两表之间的关系连线,关系连线将变粗,表明已经选择了该关系,然后按Delete键,则可删除关系。
【例4-10】以“学生管理”数据库为例,建立“学生”表与“选课”表一对多的关系;“课程”表与“选课”表一对多的关系。
①为表建立索引。
②建立表间关系。
如图4-19所示。
图4-19 建立【例4-10】表间关系4.5.3 数据库表间的参照完整性所谓参照完整性,就是根据一系列规则来保持数据的一致性,保持已定义的表间关系。
如果。
数据完整性

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

4. 修改被参照关系中主码的问题
两种策略 不允许修改主码 允许修改主码 违约操作 要修改被参照关系中某些元组的主码值,而 修改被参照关系中某些元组的主码值 中某些元组的主码值, 参照关系中有些元组的外码值正好等于被参 照关系要修改的主码值,如修改Student学号; 照关系要修改的主码值,如修改 学号; 学号
受限插入:系统将拒绝向 关系插入 关系插入( 受限插入:系统将拒绝向SC关系插入(99001, , 1,90)元组. , )元组. 递归插入:系统将首先向 递归插入:系统将首先向Student关系插入 关系插入 Sno=99001的元组,然后向 关系插入 的元组, 的元组 然后向SC关系插入 (99001,1,90)元组. , , )元组.
级联修改 修改被参照关系中主码值同时, 修改被参照关系中主码值同时,用相同的方法修改 参照关系中相应的外码值; 参照关系中相应的外码值; 受限修改 拒绝此修改操作. 拒绝此修改操作.只当参照关系中没有任何元组的 外码值等于被参照关系中某个元组的主码值时, 外码值等于被参照关系中某个元组的主码值时,这 个元组的主码值才能被修改; 个元组的主码值才能被修改; 置空值修改 修改被参照关系中主码值, 修改被参照关系中主码值,同时将参照关系中相应 的外码值置为空值; 的外码值置为空值;
实体完整性
表中的Sno, Cno定义为码 例:将SC表中的 表中的 定义为码
CREATE TABLE SC ( Sno CHAR(7) NOT NULL, Cno CHAR(4) NOT NULL, Grade SMALLINT, PRIMARY KEY (Sno, Cno), );
实体完整性
实体完整性检查和违约处理
3.在参照关系中插入元组时的问题 在参照关系中插入元组时的问题
数据完整性培训资料

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,按什么分组。
数据库表设计的四条原则

数据库表设计的四条原则
一、完整性原则:
完整性原则,是指一个关系数据库描述的实体或事实的完整性,它规定一个属性的值必须存在,但不要求一定是有效的值。
它可以防止数据库中出现空值带来的记录不完整的现象,确保数据库记录的完整性。
二、唯一性原则:
唯一性原则,是指一个表中列(字段)的唯一性原则。
它规定一个属性不能在同一表中两个记录中出现重复值,以防止表中有相同记录造成交叉参照,造成数据库信息不一致。
三、实体完整性原则:
实体完整性原则是指,一个实体间的各属性之间的相互关系必须是完整的,也就是所有的属性都必须是可以被完整的表达出来的,不能出现有一个属性无法被完整表达出来的现象。
实体完整性原则主要是为了防止一组实体属性不能正确地表述实体间的相关关系,而且它能够保证数据库的准确性。
四、参照完整性原则:
参照完整性原则是指,一个表中的数据项之间的参照完整性必须被保证。
它要求数据表中的信息必须完整,而不是只有部分信息,以便能够完全反映出数据表中的记录之间的一一对应关系,同时也是为了防止某一记录在引用另一记录时出现某种异常情况,从而影响到数据的正确性和一致性。
关系完整性

σ π
÷
关系代数
传统的集合运算
一、并(union)
设R和S是两个关系,它们的并运算是将两个关系中的所有元组构 成一个新关系,即由属于R或属于S的元素组成,该关系用R∪S, 也可以记做R+S。 【例】有在职职工和离退修职工两个表,若需要所有职工的表, 可以利用并运算实现。
工号 106001 姓名 张春来 性别 男 状态 1 工号 姓名 性别 状态 工号 106001 103026 105008 106008 104012 姓名 张春来 马宏明 王红 李建新 王红 性别 男 男 女 男 女 状态 1 1 1 0 0
801 802 803 804 805 张三 李四 王五 赵六 钱七 女 男 男 女 男 01 01 01 02 02 19 20 20 20 19 01 02 信息管理 档案学
关系的完整性
参照完整性
三、参照完整性规则
若属性(或属性组)F是基本关系R的外码它与基本关系S 的主码Ks相对应(基本关系R和S不一定是不同的关系), 则对于R中每个元组在F上的值必须为:
关系R和S不一定是不同的关系 目标关系S的主码Ks 和参照关系的外码F必须定义在同一个(或 一组)域上外码并不一定要与相应的主码同名,当外码与相应的 主码属于不同关系时,往往取相同的名字,以便于识别
关系的完整性
参照完整性
二、外码(Foreign Key)
例如,学生表中,“专业号”不是码,但它与专业表中的 码“专业号”相对应,所有,“专业号”属性是学生表的 外码。 性别 专业号 年龄 学号 姓名 专业号 专业名
课程(课程号,课程名,学分)关系中,“课程名”属性必须取唯一值, 非主属性“课程名”也不能取空值,“学分”属性只能取值{1,2,3, 4}。 所以,用户定义的完整性通常是定义属性取值的约束,即对属性的值 域的约束。对属性的值域的约束也称为域完整性规则是指对关系中属 性取值的正确性限制。包括数据类型、精度、取值范围、是否允许空 值等。