关系数据库的模式设计习题及答案

上传人:痛*** 文档编号:100467935 上传时间:2022-06-02 格式:DOC 页数:12 大小:89.50KB
收藏 版权申诉 举报 下载
关系数据库的模式设计习题及答案_第1页
第1页 / 共12页
关系数据库的模式设计习题及答案_第2页
第2页 / 共12页
关系数据库的模式设计习题及答案_第3页
第3页 / 共12页
资源描述:

《关系数据库的模式设计习题及答案》由会员分享,可在线阅读,更多相关《关系数据库的模式设计习题及答案(12页珍藏版)》请在装配图网上搜索。

1、-数据库原理之关系数据库的模式设计课后习题及答案4.1名词解释(1) 函数依赖:FD(function dependency),设有关系模式R(U),*,Y是U的子集, r是R的任一具体关系,如果对r的任意两个元组t1,t2,由t1*=t2*导致t1Y=t2Y, 则称*函数决定Y,或Y函数依赖于*,记为*Y。*Y为模式R的一个函数依赖。 (2) 函数依赖的逻辑蕴涵:设F是关系模式R的一个函数依赖集,*,Y是R的属性子集, 如果从F中的函数依赖能够推出*Y,则称F逻辑蕴涵*Y,记为F|=*Y。 (3) 局部函数依赖:即局部依赖,对于一个函数依赖WA,如果存在*W(*包含于W)有*A成立, 则称W

2、A是局部依赖,否则称WA为完全依赖。 (4)完全函数依赖:见上。 (5) 传递依赖:在关系模式中,如果Y*,*A,且*Y*不决定Y, A*A不属于*,则称YA是传递依赖。 (6) 函数依赖集F的闭包F+: 被逻辑蕴涵的函数依赖的全体构成的集合,称为F的闭包(closure),记为F+。 (7) 1NF:第一式。如果关系模式R的所有属性的值域中每一个值都是不可再分解的值, 则称R是属于第一式模式。如果*个数据库模式都是第一式的,则称该数据库存模式属于第一式的数据库模式。 第一式的模式要求属性值不可再分裂成更小局部,即属性项不能是属性组合和组属性组成。 (8) 2NF:第二式。如果关系模式R为第一

3、式,并且R中每一个非主属性完全函数依赖于R的*个候选键, 则称是第二式模式;如果*个数据库模式中每个关系模式都是第二式的,则称该数据库模式属于第二式的数据库模式。 (注:如果A是关系模式R的候选键的一个属性,则称A是R的主属性,否则称A是R的非主属性。) (9)3NF:第三式。如果关系模式R是第二式,且每个非主属性都不传递依赖于R的候选键, 则称R是第三式的模式。如果*个数据库模式中的每个关系模式都是第三式,则称为3NF的数据库模式。 (10)BF:BC式。如果关系模式R是第一式,且每个属性都不传递依赖于R的候选键,则称R是BF的模式。 (11) 4NF:第四式。设R是一个关系模式,D是R上的

4、多值依赖集合。如果D中成立非平凡多值依赖*Y时, *必是R的超键,则称R是第四式的模式。 (12)推理规则的正确性和完备性:正确性是指,如果*Y是从推理规则推出的,则*Y在F+中。 完备性是指,不能从F使用推理规则导出的函数依赖不在F+中。 (13)依赖集的覆盖和等价:关系模式R(U)上的两个函数依赖集F和G,如果满足F+=G+,则称F和G是等价的。 如果F和G等价,则可称F覆盖G或G覆盖F。 (14)最小依赖集:如果函数集合F满足以下三个条件:(1)F中每个函数依赖的右部都是单属性; (2)F中的任一函数依赖*A,其F-*A与F是不等价的;(3)F中的任一函数依赖*A,Z为*的子集,F-*A

5、ZA与F不等价。则称F为最小函数依赖集合,记为Fmin。 (15)无损联接:设R是一关系模式,分解成关系模式=R1,R2.,Rk,F是R上的一个函数依赖集。 如果对R中满足F的每一个关系r都有r=R1(r)R2(r).Rk(r)则称这个分解相对于F是无损联接分解。 (16)保持依赖集:所谓保持依赖就是指关系模式的函数依赖集在分解后仍在数据库中保持不变, 即关系模式R到=R1,R2,.,Rk的分解,使函数依赖集F被F这些Ri上的投影蕴涵。 (17)多值依赖:设R(U)是属性集U上的一个关系模式,*,Y,Z是U的子集,并且Z=U-*-Y, 用*,y,z分别代表属性集*,Y,Z的值,只要r是R的关系

6、,r中存在元组(*,y1,z1)和(*,y2,z2)时, 就也存在元组(*,y1,z2)和(*,y2,z1),则称多值依赖(MultiValued Dependency MVD) *Y在关系模式R中成立。 4.2 关系模式R有n个属性,在模式R上可能成立的函数依赖有多少个 其中平凡的函数依赖有多少个非平凡的函数依赖有多少个 (要考虑所有可能的情况,数学排列组合问题。对于数据库本身而言,此题没多大意义 所有属性相互依赖时,函数依赖最多。 平凡的函数依赖:对于函数依赖*Y,如果Y*,则称*Y是一个平凡的函数依赖。 4.3 建立关于系、学生、班级、社团等信息的一个关系数据库, 一个系有假设干个专业,

7、每个专业每年只招一个班,每个班有假设干个学生,一个系的学生住在同一宿舍区, 每个学生可以参加假设干个社团,每个社团有假设干学生。 描述学生的属性有:*、出生年月、系名、班级号、宿舍区。 描述班级的属性有:班级号、专业名、系名、人数、入校年份。 描述系的属性有:系名、系号、系办公地点、人数。 描述社团的属性有:社团名、成立年份、地点、人数、学生参加*社团的年份。 请给出关系模式,写出每个关系模式的最小函数依赖集,指出是否存在传递函数依赖, 对于函数依赖左部是多属性的情况,讨论函数依赖是完全函数依赖还是局部函数依赖。 指出各关系的候选键、外部键,有没有全键存在 各关系模式如下: 学生(*,出生年月

8、,系名,班级号,宿舍区) 班级(班级号,专业名,系名,人数,入校年份) 系(系名,系号,系办公地点,人数) 社团(社团名,成立年份,地点,人数 参加社团社团名,*,学生参加社团的年份 学生(*,出生年月,系名,班级号,宿舍区)学生关系的最小函数依赖集为: Fmin=*,*班级号,*出生年月,*系名,系名宿舍区 以上关系模式中存在传递函数依赖,如:*系名,系名宿舍区 候选键是*,外部键是班级号,系名。 notice: 在关系模式中,如果Y*,*A,且*Y*不决定Y, A不属于*,则称YA是传递依赖。 班级(班级号,专业名,系名,人数,入校年份) 班级关系的最小函数依赖集为: Fmin=(系名,专

9、业名)班级号,班级号人数,班级号入校年份,班级号系名,班级号专业名 (假设没有一样的系,不同系中专业名可以一样) 以上关系模式中不存在传递函数依赖。 (系名,专业名)班级号是完全函数依赖。 候选键是(系名,专业名),班级号,外部键是系名。 系(系名,系号,系办公地点,人数) 系关系的最小函数依赖集为: Fmin=系号系名,系名系办公地点,系名人数,系名系号 以上关系模式中不存在传递函数依赖 候选键是系名,系号 社团(社团名,成立年份,地点,人数 社团关系的最小函数依赖集为: Fmin=社团名成立年份,社团名地点,社团名人数) 以上关系模式中不存在传递函数依赖。 候选键是社团名 参加社团社团名,

10、*,学生参加社团的年份参加社团关系的最小函数依赖集为: Fmin=社团名,*学生参加社团的年份) 社团名,*学生参加社团的年份是完全函数依赖。以上关系模式中不存在传递函数依赖。 候选键是社团名,*。4.4 对函数依赖*Y的定义加以扩大,*和Y可以为空属性集,用表示, 则*,Y,的含义是什么 根据函数依赖的定义,以上三个表达式的含义为: (1)一个关系模式R(U)中,*,Y是U的子集,r是R的任一具体关系,如果对r的任意两个元组t1,t2, 由t1*=t2*必有t1=t2。即*表示空属性函数依赖于*。这是任何关系中都存在的。 (2)Y表示Y函数依赖于空属性。由此可知该关系中所有元组中Y属性的值均

11、一样。 (3)表示空属性函数依赖于空属性。这也是任何关系中都存在的。 4.5 关系模式R(ABC),F=AC,BC,求F+。 可以直接通过自反律、增广律、传递律加以推广: F+=,A,B,C,AC,BC,AB,ABA,ABB,ABC,ABBC,ABAB,ABABC,BC,BCC,BCB,BCBC,AC,ACC,ACA,ACAC,ABC,ABCA,ABCB,ABCC,ABCBC,ABCAB,ABCABC4.6 试分析以下分解是否具有无损联接和保持函数依赖的特点: (1)设R(ABC),F1=AB 在R上成立,1=AB,AC。 首先,检查是否具有无损联接特点: 第1种解法-算法4.2:ABCABa

12、1a2b13ACa1b22a3ABCa1a2b13a1a2a3(1) 构造表(2)根据AB进展处理结果第二行全是a行,因此分解是无损联接分解。 第2种解法:(定理4.8) 设 R1=AB,R2=AC R1R2=A R2- R1=B AB,该分解是无损联接分解。 然后,检查分解是否保持函数依赖 R1F1=AB,以及按自反率推出的一些函数依赖 R2F1=按自反率推出的一些函数依赖 F1被R1F1所蕴涵,所以该分解保持函数依赖。 (2)设R(ABC),F2=AC,BC在R上成立,2=AB,AC 首先,检查是否具有无损联接特点: 第1种解法略 第2种解法:(定理4.8) 设 R1=AB,R2=AC R

13、1R2=A R2- R1=C AC,该分解是无损联接分解。 然后,检查分解是否保持函数依赖 R1F2=按自反率推出的一些函数依赖 R2F2=AC,以及按自反率推出的一些函数依赖 F1中的BC没有被蕴涵,所以该分解没有保持函数依赖。 (3)设R(ABC),F3=AB,在R上成立,3=AB,BC. 首先,检查是否具有无损联接特点: 第1种解法: ABCABa1a2b13BCb21a2a3ABCa1a2a3a1b22a3(1) 构造表(2)根据AB进展处理没有一行全是a行。因此这个分解不具有无损联接特性。 第2种解法:(定理4.8) 设 R1=AB,R2=BC R1R2=B R2- R1=C,R1-

14、 R2=A BC,BA不在F3中 该分解不具有无损联接特性。然后,检查分解是否保持函数依赖 R1F3=AB,以及按自反率推出的一些函数依赖 R2F3=按自反率推出的一些函数依赖 F1被R1F3所蕴涵,所以该分解保持函数依赖。 (4)设R(ABC),F4=AB,BC在R上成立,4=AC,BC 首先,检查是否具有无损联接特点: 第1种解法略 第2种解法:(定理4.8) 设 R1=AC,R2=BC R1(AC)R2(BC)=C R2- R1=B,R1- R2=A CB,CA不在F4中该分解不具有无损联接特性。 然后,检查分解是否保持函数依赖 R1F2=按自反率推出的一些函数依赖 R2F2=BC,以及

15、按自反率推出的一些函数依赖 F1中的AB没有被蕴涵,所以该分解没有保持函数依赖。4.7 设R=ABCD,R上的函数依赖集F=AB,BC,AD,DC,R的一个分解=AB,AC,AD,求:(1)F在的每个模式上的投影。(2)相对于F是无损联接分解吗(3)保持依赖吗 (1) AB(F)=AB,及按自反律所推导出的一些平凡函数依赖 AC(F)=AC,及按自反律所推导出的一些平凡函数依赖 AD(F)=AD,及按自反律所推导出的一些平凡函数依赖 (2) ABCDABa1a2b13b14ACa1b22a3b24ADa1b32b33a4ABCDa1a2a3a4a1a2a3a4a1a2a3a4(1) 构造表(2

16、)根据AB,BC,AD,DC进展处理每一行都是a,相对于F是无损联接分解。 (3)AB(F)AC(F)AD(F)=AB,AC,AD, 没有满足BC,DC函数依赖, 因此相对于F的这个分解不保持函数依赖。 4.8 设R=ABCD,R上的F=AC,DC,BDA, 试证明=AB,ACD,BCD相对于F不是无损联接分解。 根据算法4.2 ABCDABa1a2b13b14ACDa1b22a3a4BCDb31a2a3a4ABCDa1a2a3b14a1b22a3a4b31a2a3a4(1) 构造表(2)根据AC,DC,BDA进展处理没有一行都是a,所以,相对于F不是无损联接分解。 4.9 设R=ABCD,R

17、上的F=AB,BC,DB,把R分解成BF模式集。 (1)假设首先把R分解成ACD,BD,试求F在这两个模式上的投影。 (2)ACD和BD是BF吗如果不是,请进一步分解。 (1)ACD(F)=AC BD(F)=DB (2)因为根据BF的定义,要求关系模式是第一式,且每个属性都不传递依赖于R的侯选键。 BCD中A,D为候选键,可是A,D)A, AC,所以它不是BF模式。 它可进一步分解为:AC,DC,此时AC,DC均为BF模式。 BD是BF,因为R2(BD)是第一式,且每个属性都不传递依赖于D(候选键),所以它是BF模式。 4.10 设R=ABCD,=AB,BC,CD。F1=AB,BC;F2=BC

18、,CD; (1)如果F1是R上的函数依赖集,此时是无损联接分解吗假设不是,试举出反例。 (2)如果F2是R上的函数依赖集呢 (1)不是无损联接。可由算法4.2判断或由定理4.8判断。 根据算法4.2 ABCDABa1a2b13b14BCb21a2a3b24CDb31b32a3a4ABCDa1a2a3b14b21a2a3b24b31b32a3a4(1) 构造表(2)根据AB,BC进展处理结果没有出现一行全a的情况,所以它不是无损联接。举例如下: 设模式R的一关系r为(a1b1c1d1),(a2b2c1d2) 则有:r1=AB(r)=(a1b1),(a2b2) r2=BC(r)=(b1c1),(b

19、2c1) r3=CD(r)=(c1d1),(c1d2) 令a=r1r2r3= (a1b1c1d1),(a1b1c1d2),(a2b2c1d1),(a2b2c1d2) ra,所以不是无损联接。 (2)如果F2是R上的函数依赖,则可以判断,是无损联接。判断过程同上。 4.11 设关系模式R(S#,C#,GRADE,TNAME,TADDR),其属性分别表示学生*、 选修课程的编号,成绩、任课教师地址等意义。如果规定,每个学生每学一门课只有一个成绩; 每门课只有一个教师任教;每个教师只有一个地址(此处不允许教师同名同姓)。 (1)试写出关系模式R根本的函数依赖和候选键。 (2)试把R分解成2NF模式集

20、并说明理由。 (3)试把R分解成3NF模式集,并说明理由。 (1)F=(S#,C#)GRADE,C#TNAME,TNAMETADDR 侯选键是S#,C#。 (2)在模式R中,TNAME不完全依赖于键(S#,C#),因此需进展分解,可分解为以下两个关系。 SC=S#,C#,GRADE C=C#,TNAME,TADDR 分解后,SC中,GRADE完全依赖于侯选键(S#,C#),在C中,主属性是C#,TNAME、TADDR均完全依赖于C#。 因此,该分解符合2NF模式。 (3)3NF:假设每个关系模式是2NF,则每个非主属性都不传递于R的候选键。 按上述已分好的两个模式,SC中已满足每个非主属性都不

21、传递于R的候选键,已是3NF,而在C中, C#TNAME,TNAMETADDR,TADDR传递依赖于C#,因此还需分成两个模式:CT(C#,TNAME), T(TNAME,TADD)。 分解后,总共有SC=S#,C#,GRADE,CT(C#,TNAME), T(TNAME,TADD)三个模式。 该分解符合3NF模式。 4.12 图4.6表示一个公司各部门的层次构造,对每个部门,数据库中包含部门号 (唯一的)D#,预算费(BUDGET)以及此部门领导人员的职工号(唯一的)E#等信息。 对每一个部门,还存有部门的全部职工,生产科研工程以及办公室的信息。 职工信息包括:职工号,他所参加的生产科研工程

22、号(J#),他所在办公室的号(PHONE#)。 生产科研工程包含:工程号(唯一的),预算费。 办公室信息包含:办公室号(唯一的),面积。 对每个职工,数据库中有他曾担任过的职务以及担任*一职务时的工资历史。对每个办公室包含此办公室中全部号吗的信息。 请给出你认为合理的数据依赖,把这个层次构造转换成一组规化的关系。 提示:此题可分步完成,先转换成一组1NF的关系,然后逐步转换成2NF,3NF,.。 先得到一个泛关系的模式如下: D=D#,Manager_E#,Budget,E#,J#,Phone#,Business,Sa_History,Office#,Area D#:部门号, Manager_

23、E#:部门领导人员的职工号, E#:职工号, J#:生产科研工程号, Phone#:办公室的号,Business:职工职务,Sa_History:工资历史,Office#:办公室号,Area:办公室面积 根据所给信息,给出以下数据依赖: F=D#Manager_E#,E#Office#,(E#,Business)Sa_History,J#Budget,E#J#, Office#Area,OfficeD#,#Phone#Office# 假设一个部门可能有多个办公室,有多个工程,一个办公室只属于一个部门,有多部, 一个员工只参加一个工程,一个工程可能属于多个部门 只要保证每个属性值不可分割,以上式

24、即为1NF。候选键为E#,Business,Phone#) 转换成2NF关系(消除局部依赖: Em_Dep(E#,D#,Manager_E#,Office#,Area,J#,Budget) 对应 F=D#Manager_E#,E#Office#,J#Budget,E#J#,Office#Area,OfficeD# History(E#,Business,History) 对应 F=(E#,Business)Sa_History Phone(Phone#,Office#) 对应 F=Phone#Office# 转换成3NF关系(消除非主属性对侯选键的传递依赖: Department(D#,Man

25、ager_E#) Office(Office#,Area,D#) Emproee(E#,J#,Office#) History(E#,Business,History) Phone(Phone#,Office#) Project(J#,Budget) 注意:由于对题意理解的不同,可能答案不唯一。 4.13 设关系模式R(ABC)上有一个多值依赖AB。 如果R的当前关系中存在三组(ab1c1)、(ab2c2)和(ab3c3),则这个关系中至少还应存在哪些元组 从多值依赖的定义可以得出,至少应存在以下元组: (ab1c2)、(ab1c3)、(ab2c1)、(ab2c3)、(ab3c1)、(ab3c2). z

展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!