参照完整性
- 格式:pdf
- 大小:856.10 KB
- 文档页数:13
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中的参照完整性(⼀对⼀,⼀对多,多对多)⼀、参照完整性参照完整性指的就是多表之间的设计,主要使⽤外键约束。
多表设计: ⼀对多、多对多、⼀对⼀设计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: 约束的意思。
一、有效性规则和参照完整性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,按什么分组。
数据库表设计的四条原则
一、完整性原则:
完整性原则,是指一个关系数据库描述的实体或事实的完整性,它规定一个属性的值必须存在,但不要求一定是有效的值。
它可以防止数据库中出现空值带来的记录不完整的现象,确保数据库记录的完整性。
二、唯一性原则:
唯一性原则,是指一个表中列(字段)的唯一性原则。
它规定一个属性不能在同一表中两个记录中出现重复值,以防止表中有相同记录造成交叉参照,造成数据库信息不一致。
三、实体完整性原则:
实体完整性原则是指,一个实体间的各属性之间的相互关系必须是完整的,也就是所有的属性都必须是可以被完整的表达出来的,不能出现有一个属性无法被完整表达出来的现象。
实体完整性原则主要是为了防止一组实体属性不能正确地表述实体间的相关关系,而且它能够保证数据库的准确性。
四、参照完整性原则:
参照完整性原则是指,一个表中的数据项之间的参照完整性必须被保证。
它要求数据表中的信息必须完整,而不是只有部分信息,以便能够完全反映出数据表中的记录之间的一一对应关系,同时也是为了防止某一记录在引用另一记录时出现某种异常情况,从而影响到数据的正确性和一致性。
参照完整性
引用完整性指的是关系中数据的准确性和一致性。
在关系中,数据在两个或多个表之间链接。
这是通过让外键(在关联表中)引用主键值(在主表或父表中)来实现的。
因此,我们需要确保关系双方的数据保持完整。
因此,参照完整性要求每当使用外键值时,它必须引用父表中有效的现有主键。
例子
例如,如果我们删除主表中的第15行,我们需要确保任何相关表中没有值为15的外键。
如果没有关联的行,我们应该只删除主键。
否则,我们将以孤立的记录告终。
这里,相关表包含一个主表的主键字段(即
“CompanyId”字段)中不存在的外键值。
这导致了
“孤立记录”。
因此参照完整性将阻止用户:
•如果主表中没有关联的行,则将该行添加到相关表中。
•更改主表中的值将导致相关表中的孤立记录。
•如果有匹配的相关行,则从主表中删除这些行。
缺乏参照完整性的后果
数据库中缺乏参照完整性可能导致返回的数据不完整,通常没有错误指示。
这可能会导致记录在数据库中“丢失”,因为它们永远不会在查询或报告中返回。
还可能导致报告出现奇怪的结果(比如没有关联公司的产品)。
或者更糟的是,这可能会导致客户收不到他们购买的产品。
更糟糕的是,它可能会影响到生死攸关的情况,例如,医院的病人没有得到正确的治疗,或者救灾小组没有收到正确的材料或信息。
数据的完整性
引用完整性是数据完整性的一个子集,它与所有数据(关系数据或其他数据)的准确性和一致性有关。
维护数据完整性是使用数据库的一个关键部分。
参照完整性规则今天,我来谈一谈关于心理学方面的知识。
所谓的参照完整性规则,是指人的情绪、动机、欲望等都会受到外界因素和内部因素的影响。
而参照完整性规则的三要素是:强度,稳定性,力比多。
人之所以为人,就是他有灵魂,有自己的思想,有自己的主观意识。
同样,作为人的属性,也不可避免地会受到外界因素和内部因素的影响。
如果想控制自己的思想,首先必须考虑到这些因素对自己的影响。
例如,当我的成绩优秀时,我希望别人能够称赞我,如果我没有做出什么成绩,我就会担心别人怎么看待我。
这种担心和怀疑正是由于内部因素和外部因素的影响,这时候就需要用到参照完整性规则。
其实说白了,参照完整性规则就是人们在生活中处理问题或困难时的心理机制。
人们都是活在一个完整的世界中,但各个部分相互作用的过程使得每个部分不断扩张,最终形成一个整体,从而使得社会结构更加复杂。
参照完整性规则在现代社会,已经被广泛运用到社会活动中,人们在面对紧急事件或重大决策时,都习惯性地运用参照完整性规则。
它有助于我们解释行为,并根据某些特殊因素预测行为的发展趋势。
这也是为什么很多专家认为,一个人的发展变化并不是由基因决定的,更多是由外界因素和内部因素共同影响而造成的。
这也与小孩子学走路的原理差不多。
婴儿在一岁半之前,不会走路也不会爬,但他们却是靠内部因素的支撑站立起来的,所以在这个阶段只有适应环境,才能获得更好的发展。
因此,在我们人生的道路上,不管遇到什么样的困难,都需要用积极乐观的态度去解决,而不是悲观厌世,人生不如意十之八九,有时候觉得活得太累,是因为想得太多,身上背负了太多的压力,其实换个角度想想,很多事情根本就不值得我们浪费时间和精力去担忧,真的有那时间还不如多放松自己呢!随着时间的流逝,阅历的增长,参照完整性规则将会对我们的影响越来越大,因为我们正逐步接近成年,并逐渐摆脱父母的束缚,拥有自己独立的思想和意志。
因此,我们必须学会控制自己的思想,积极客观地看待自己和周围的世界,并用参照完整性规则来帮助我们在面对挫折和失败时做出理性的选择。
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根据参照
完整性规则自动进行检查并进行违约处理。