参照完整性
- 格式:ppt
- 大小:146.50 KB
- 文档页数:5
52 的“字段”选项卡中包含有字段有效性规则。
可以先选择要定义有效性的字段,然后分别输入规则、信息及默认值。
【例4-9】以“学生管理”数据库的学生表为例,设性别字段有效性规则为只允许输入“男”或“女”字符,当输入的不是要求内容时,提示输入错误,性别字段的默认值为“男”。
在“规则”框中输入:性别="男" OR 性别="女"。
在“信息”框中输入:"性别输入错误!"。
在“默认值”框中输入:"男"。
“规则”是逻辑表达式,“信息”是字符串表达式,“默认值”的类型由字段的类型确定。
4.5.2 数据库表间的永久关系自由表之间可以建立临时关系,数据库表之间可以建立永久关系,永久关系保存在数据库中,不必在每次使用时重新建立。
在Visual FoxPro中,可以使用索引在数据库中建立表间的永久关系。
1.建立数据库表间的永久关系可以在数据库设计器中,选择想要关联的索引名,然后把它拖到相关表的索引名上。
在创建永久关系时,作为主表的索引必须使用主索引或候选索引,否则无法建立永久关系。
2.删除数据库表间的永久关系可以在数据库设计器中,单击两表之间的关系连线,关系连线将变粗,表明已经选择了该关系,然后按Delete键,则可删除关系。
【例4-10】以“学生管理”数据库为例,建立“学生”表与“选课”表一对多的关系;“课程”表与“选课”表一对多的关系。
①为表建立索引。
②建立表间关系。
如图4-19所示。
图4-19 建立【例4-10】表间关系4.5.3 数据库表间的参照完整性所谓参照完整性,就是根据一系列规则来保持数据的一致性,保持已定义的表间关系。
如果。
关系模型的参照完整性规则
答: 关系模型的完整性规则是对关系的某种约束条件。
关系模型中可以有三类完整性约束:实体完整性、参照完整性和用户定义的完整性。
其中实体完整性和参照完整性是关系模型必须满足的完整性约束条件,被称作是关系的两个不变性,应该由关系系统自动支持。
1) 实体完整性规则:若属性A是基本关系R的主属性,则属性A不能取空值。
2) 参照完整性规则:若属性(或属性组)F是基本关系R的外码,它与基本关系S的主码Ks相对应(基本关系R和S不一定是不同的关系),则对于R中每个元组在F上的值必
须为:
·或者取空值(F的每个属性值均为空值);
·或者等于S中某个元组的主码值。
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.思考:⑴如果同学们在填学生表的时候将自己的班级名称写错了, 写成了一个学校中根本不存在的班级, 这样的结果肯定是错误的。
一、有效性规则和参照完整性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”字段)中不存在的外键值。
这导致了
“孤立记录”。
因此参照完整性将阻止用户:
•如果主表中没有关联的行,则将该行添加到相关表中。
•更改主表中的值将导致相关表中的孤立记录。
•如果有匹配的相关行,则从主表中删除这些行。
缺乏参照完整性的后果
数据库中缺乏参照完整性可能导致返回的数据不完整,通常没有错误指示。
这可能会导致记录在数据库中“丢失”,因为它们永远不会在查询或报告中返回。
还可能导致报告出现奇怪的结果(比如没有关联公司的产品)。
或者更糟的是,这可能会导致客户收不到他们购买的产品。
更糟糕的是,它可能会影响到生死攸关的情况,例如,医院的病人没有得到正确的治疗,或者救灾小组没有收到正确的材料或信息。
数据的完整性
引用完整性是数据完整性的一个子集,它与所有数据(关系数据或其他数据)的准确性和一致性有关。
维护数据完整性是使用数据库的一个关键部分。
举例说明关系参照完整性的含义
关系参照完整性是数据库设计中的一个重要概念,它是指在数据库中,一个表中的每一行都必须有一个有效的外键,以确保数据的完整性。
举例来说,假设有一个学生表,其中包含学生的姓名、年龄、性别等信息,还有一个班级表,其中包含班级的名称、班主任等信息。
如果要在学生表中添加一个学生,那么必须确保该学生所在的班级在班级表中存在,否则就会出现数据不完整的情况。
另外,关系参照完整性还可以用来防止数据库中出现重复数据。
例如,如果在学生表中添加一个学生,那么必须确保该学生的学号在学生表中是唯一的,否则就会出现重复数据的情况。
总之,关系参照完整性是数据库设计中的一个重要概念,它可以确保数据的完整性和唯一性,从而避免出现数据不完整和重复数据的情况。
参照完整性规则今天,我来谈一谈关于心理学方面的知识。
所谓的参照完整性规则,是指人的情绪、动机、欲望等都会受到外界因素和内部因素的影响。
而参照完整性规则的三要素是:强度,稳定性,力比多。
人之所以为人,就是他有灵魂,有自己的思想,有自己的主观意识。
同样,作为人的属性,也不可避免地会受到外界因素和内部因素的影响。
如果想控制自己的思想,首先必须考虑到这些因素对自己的影响。
例如,当我的成绩优秀时,我希望别人能够称赞我,如果我没有做出什么成绩,我就会担心别人怎么看待我。
这种担心和怀疑正是由于内部因素和外部因素的影响,这时候就需要用到参照完整性规则。
其实说白了,参照完整性规则就是人们在生活中处理问题或困难时的心理机制。
人们都是活在一个完整的世界中,但各个部分相互作用的过程使得每个部分不断扩张,最终形成一个整体,从而使得社会结构更加复杂。
参照完整性规则在现代社会,已经被广泛运用到社会活动中,人们在面对紧急事件或重大决策时,都习惯性地运用参照完整性规则。
它有助于我们解释行为,并根据某些特殊因素预测行为的发展趋势。
这也是为什么很多专家认为,一个人的发展变化并不是由基因决定的,更多是由外界因素和内部因素共同影响而造成的。
这也与小孩子学走路的原理差不多。
婴儿在一岁半之前,不会走路也不会爬,但他们却是靠内部因素的支撑站立起来的,所以在这个阶段只有适应环境,才能获得更好的发展。
因此,在我们人生的道路上,不管遇到什么样的困难,都需要用积极乐观的态度去解决,而不是悲观厌世,人生不如意十之八九,有时候觉得活得太累,是因为想得太多,身上背负了太多的压力,其实换个角度想想,很多事情根本就不值得我们浪费时间和精力去担忧,真的有那时间还不如多放松自己呢!随着时间的流逝,阅历的增长,参照完整性规则将会对我们的影响越来越大,因为我们正逐步接近成年,并逐渐摆脱父母的束缚,拥有自己独立的思想和意志。
因此,我们必须学会控制自己的思想,积极客观地看待自己和周围的世界,并用参照完整性规则来帮助我们在面对挫折和失败时做出理性的选择。
实验3 数据库完整性目录实验1.1 实体完整性 (1)实验1.2参照完整性 (1)实验1.3 触发器的应用 (1)实验1.1 实体完整性1)在数据库School中建立表Stu_Union,进行主键约束,在没有违反实体完整性的前提下插入并更新一条记录2)演示违反实体完整性的插入操作3)演示违反实体完整性的更新操作实验1.2参照完整性1)为演示参照完整性,建立表Course,令cno为其主键,并在Stu_Union中插入数据。
为下面的实验步骤做预先准备。
2)建立表sc,另sno和cno分别为参照Stu_Union表以及Course表的外键,设定为级连删除,并令(sno, cno)为其主键。
在不违反参照完整性的前提下,插入数据。
3)演示违反参照完整性的插入数据4)在Stu_Union中删除数据,演示级连删除。
5)Course中删除数据,演示级连删除。
6)为了演示多重级连删除,建立Stu_Card表,令stu_id为参照Stu_Union表的外键,令card_id 为其主键,并插入数据。
7)为了演示多重级连删除,建立ICBC_Card表,令stu_card_id为参照Stu_Card表的外键,令bank_id为其主键,并插入数据。
8)通过删除students表中的一条记录,演示三个表的多重级连删除。
实验1.3 触发器的应用重要提示:在做以下练习前,先删除sc对stu_union的外键引用1)在表sc中演示触发器的insert操作,当学生成绩低于60分时,自动改为60,并在事先创建的记录表中插入一条学生成绩低于60的记录。
提示:另外创建一个表记录成绩低于60分的学生的真实记录。
2)在表stu_union中创建行级触发器,触发事件是UPDATE。
当更新表stu_union的Sid时,同时更新sc中的选课记录。
提示:这个触发器的作用实际上相当于具有CASCADE参数的外键引用。
3)在表stu_union中删除一学生的学号(演示触发器的delete 操作),使他在sc中关的信息同时被删除。
实施参照完整性的作⽤
实施参照完整性⼀般是创建外键表关联的时候使⽤.
我以⼀个例⼦来说明。
例如有2个表。
⼀个班级表,⼀个学⽣表
班级表(班级编号,班级名称,班级其他字段... )
学⽣表(学号,所属班级编号,学⽣名,学⽣其他字段 ...)
当在班级表与学⽣表之间,创建⼀个关联的时候,也就是学⽣表的 “所属班级编号” 与班级表的 “班级编号” 建⽴关联的时候。
"实施参照完整性" 意味着,当你向学⽣表插⼊数据的时候,如果输⼊了⼀个班级表⾥⾯,还没有的班级编号,那么数据库将报错,不允许你这么做。
也就是如果班级表有 1,2,3 共三个班级。
⽽你插⼊了⼀个学⽣张三,所在班级是 5班的。
那么数据库直接报错了。
这就是 "实施参照完整性" 的效果。
⽬的是为了避免,数据库中,产⽣垃圾数据。
也就是如果软件开发⼈员,在写程序的时候,不⼩⼼,忘记检查某些数据合法性的情况下,数据库最底层,还能做最后⼀次检查。
简述参照完整性规则
参照完整性则是相关联的两个表之间的约束,具体的说,就是从表中每条记录外键的
值必须是主表中存在的,因此,如果在两个表之间建立了关联关系,则对一个关系进行的
操作要影响到另一个表中的记录。
参照的完整性要求关系中不允许引用不存在的实体。
与实体完整性是关系模型必须满
足的完整性约束条件,目的是保证数据的一致性。
参照完整性又称引用完整性。
比如,如果在学生表和课外之间用学号创建关联,学生集是主表,课外从表中,那么,在向从表输出一条崭新记录时,系统必须检查崭新记录的学号与否在主表中已存有,如果
存有,则容许继续执行输出操作方式,否则婉拒输出,这就是参考完整性。
参照完整性还体现在对主表中的删除和修改操作,例如,如果删除主表中的一条记录,则从表中凡是外键的值与主表的主键值相同的记录也会被同时删除,将此称为级联删除;
如果修改主表中主关键字的值,则从表中相应记录的外键值也随之被修改,将此称为级联
删除。
模块五创建和编辑数据表
实验十建立表之间的关系和实施参照完整性学号:1100110719 姓名:苏以文实验日期:2011.12.29
一、实验目的
1.掌握创建和修改Access2003数据表之间的关系的方法。
2.了解实施参照完整性的含义
二、实验内容及步骤
实验二部分:
一、在表之间如何建立关系,请描述建立关系的关键步骤(可截图说明)
答:关闭要建立表间关系的表,打开“显示表”对话框,选择建立表间关系的数据表,建立表间关系,设置完整性,保存建立的表间关系,编辑关系,显示建立关系后的主表和从表。
二、什么是“实施参照完整性”,如何设置
答:当主表中没有相关记录时,不能将记录添加到相关表中。
在“编辑关系”中选择“实施参照完整性”
三、级联更新和级联删除的作用是什么
答:级联更新使得主关键字段的值和关联表中相关字段的值保持同步更新。
级联删除使得主关键字段中相应的记录被删除时,会自动删除相关表中的对应记录。
四、请把你建立的表之间关系图粘贴到下方。
五、实验小结
答:通过这次试验,我学会了如何建立表间关系,而且了解到数据表之间建立关系之后,我们可以同时修改多张表,大大减少了我们的工作量,同时也可以让我们清晰的看到表与表之
间的关系。