数据库函数依赖
admin
2024-03-14 01:29:57
0

目录

  • 数据库函数依赖
    • 属性集的闭包
      • 求解属性集闭包
      • 判断函数依赖是否成立
      • 求解最小依赖集
      • 求解正则覆盖
    • 候选码的应用
      • 候选码的计算
      • 判断范式
    • 参考

数据库函数依赖

在网上看了许多有关数据库函数依赖考题的分析,大都信息不全或者讲不完整,甚至是胡言乱语,看的我也是云里雾里。在浅浅的了解一番之后,决定总结一下有关这方面的做题技巧,为了加深印象也为了应付考试,于是就有了这篇文章。

阅读须知:数据库函数依赖的部分概念非常多,也十分难理解,如果单纯看书那会发现根本看不懂(比如我,书上各式各样的符号解释让人眼花缭乱)。所以本文大都以例子来说明,碰到相关概念再展开定义。

属性集的闭包

令 α\alphaα 是一个属性集,我们将函数依赖集 FFF 下被函数确定的所有属性的集合称为 FFF 下 α\alphaα 的闭包。

求解属性集闭包

书上的算法就不看了,看了也看不懂,直接看题目。

  • 例一:计算属性闭包(BC)+(BC)^+(BC)+

Example:GivenR,R={A,B,C,D,E},F={B→CD,AD→E,B→A}Example:Given \R,R=\{A,B,C,D,E\},F=\{B\rightarrow CD,AD\rightarrow E,B\rightarrow A\} Example:GivenR,R={A,B,C,D,E},F={B→CD,AD→E,B→A}

解:
1.Result{BC}2.Result{ABCD}3.Result{ABCDE}1.Result\{BC\} \\ 2.Result\{ABCD\}\\ 3.Result\{ABCDE\} 1.Result{BC}2.Result{ABCD}3.Result{ABCDE}
很简单,只要根据函数依赖集一步步推到就可以得到,首先是闭包初始状态BCBCBC,接着分别考虑每一个状态,根据依赖 B→CD,B→AB\rightarrow CD,B\rightarrow AB→CD,B→A ,可以将 AAA 和 DDD 加入到闭包中,最后由 AD→EAD\rightarrow EAD→E,将 EEE 也加入到闭包当中。当刚求出的属性闭包与上一个闭包相同时或者已经求出了所有的属性 UUU 时,就停止计算。

  • 例二:计算属性闭包(A)+(A)^+(A)+

Example:GivenR,R={A,B,C,D,E,H},F={A→B,B→DH,A→H,C→E}Example:Given \R,R=\{A,B,C,D,E,H\},F=\{A\rightarrow B,B\rightarrow DH,A\rightarrow H,C\rightarrow E\} Example:GivenR,R={A,B,C,D,E,H},F={A→B,B→DH,A→H,C→E}

有了上面的经验,这个是不是很简单了呢?

解:
1.Result{A}2.Result{ABH}3.Result{ABDH}1.Result\{A\} \\2.Result\{ABH\}\\3.Result\{ABDH\} 1.Result{A}2.Result{ABH}3.Result{ABDH}

判断函数依赖是否成立

直接说定理:如果 YYY 属于 XXX 的属性集闭包,那么依赖 X→YX \rightarrow YX→Y 成立,反之也如此。即 X→Y⇔Y⫅(XF)+X \rightarrow Y \Leftrightarrow Y \subseteqq(X_F)^+X→Y⇔Y⫅(XF​)+

可能还是过于抽象,直接看题。还是上面的例二,问函数依赖 A→DA \rightarrow DA→D 成立吗?

解:

可以求得属性闭包(A)+={A、B、D、H}(A)^+=\{A、B、D、H\}(A)+={A、B、D、H},因为 H⫅(A)+H \subseteqq(A)^+H⫅(A)+,所以此依赖成立。

求解最小依赖集

求解最小依赖集需要用到上述判断依赖集。

还是直接上题目。

  • 例三:取下述依赖集的最小依赖集

Example:GivenR,R={A,B,C,D,E,I},F={A→C,AB→C,C→DI,CD→I,EC→AB,EI→C}Example:Given \R,R=\{A,B,C,D,E,I\},F=\{A\rightarrow C,AB\rightarrow C,C\rightarrow DI,CD\rightarrow I,EC\rightarrow AB,EI\rightarrow C\} Example:GivenR,R={A,B,C,D,E,I},F={A→C,AB→C,C→DI,CD→I,EC→AB,EI→C}

解:

第一步右部化为单属性,经过分解后上述依赖集就变成如下依赖集:
F={A→C,AB→C,C→D,C→I,CD→I,EC→A,EC→B,EI→C}F=\{A\rightarrow C,AB\rightarrow C,C\rightarrow D,C\rightarrow I,CD\rightarrow I,EC\rightarrow A,EC\rightarrow B,EI\rightarrow C\} F={A→C,AB→C,C→D,C→I,CD→I,EC→A,EC→B,EI→C}
第二步判断依赖是否可以去除。把依赖集中的每一个依赖一个个尝试,看把这个依赖去掉后,还能不能导出这个依赖关系,如果能,则依赖多余要去除;如果不能,则保留。如果看能不能导出依赖关系呢?就要用到我们上述判断函数依赖是否成立了,其实就是判断依赖式左边的闭包包不包含右边。

举例,把 A→CA\rightarrow CA→C 去掉(已经去掉了,此依赖就不可用了),就看 AAA 的闭包里还有没有 CCC,再结合之前求解闭包的方法,可以知道 (A)+={A}(A)^+=\{A\}(A)+={A},并没有 CCC,所以此依赖不多余,不可去除。再判断 AB→CAB\rightarrow CAB→C ,可得 (AB)+={A、B、C、D、I}(AB)^+=\{A、B、C、D、I\}(AB)+={A、B、C、D、I},包含 CCC,也就说明没有这个依赖,此依赖也可以得到,所以把它去掉。再继续判断下一个直到最后,需要注意的是,此时 AB→CAB\rightarrow CAB→C 已经去掉,之后的判断过程就不可再用此依赖了。

最后我们得到依赖集:
F={A→C,C→D,CD→I,EC→A,EC→B,EI→C}F=\{A\rightarrow C,C\rightarrow D,CD\rightarrow I,EC\rightarrow A,EC\rightarrow B,EI\rightarrow C\} F={A→C,C→D,CD→I,EC→A,EC→B,EI→C}
第三步判断左部冗余属性。找到依赖式左部属性大于等于2的,然后依次去除一个属性,判断剩余属性的闭包能否推断出依赖式右部,如果能,则说明去除的属性多余,去掉;如果不能,则说明去除的属性有用,保留。

由于A→C,C→DA\rightarrow C,C\rightarrow DA→C,C→D 左部已经是单属性,就不考虑。直接看第三个 CD→ICD\rightarrow ICD→I,首先去掉属性 CCC,计算 (D)+={D}(D)^+=\{D\}(D)+={D},说明没有 CCC 推不出来 III,即 CCC 不可去掉,同理删除 DDD,计算 (C)+={C、D、I}(C)^+=\{C、D、I\}(C)+={C、D、I},说明没有 DDD 也能推出来 III,即 DDD 可去掉。再依次判断接下来的几个,最后得到最小依赖集:
F={A→C,C→D,C→I,EC→A,EC→B,EI→C}F=\{A\rightarrow C,C\rightarrow D,C\rightarrow I,EC\rightarrow A,EC\rightarrow B,EI\rightarrow C\} F={A→C,C→D,C→I,EC→A,EC→B,EI→C}
整个求解过程较为繁琐。需要注意的是第二步和第三步的细微区别。第二步判断依赖是要先把依赖删除,再利用其他的依赖关系看看能不能推出来此依赖,而第三步判断冗余属性时原本的依赖式是全部可用的。

再看一个例子吧。

  • 例四:取下述依赖集的最小依赖集

Example:GivenR,R={A,B,C},F={A→BC,B→C,A→B,AB→C}Example:Given \R,R=\{A,B,C\},F=\{A\rightarrow BC,B\rightarrow C,A\rightarrow B,AB\rightarrow C\} Example:GivenR,R={A,B,C},F={A→BC,B→C,A→B,AB→C}

解:

第一步右部化为单属性,经过分解后上述依赖集就变成如下依赖集:
F={A→B,A→C,B→C,AB→C}F=\{A\rightarrow B,A\rightarrow C,B\rightarrow C,AB\rightarrow C\} F={A→B,A→C,B→C,AB→C}
第二步判断是否有多余依赖式。可以发现式子 A→C,AB→CA\rightarrow C,AB\rightarrow CA→C,AB→C 都是多余的,所以删除。

第三步由于没有左部多属性的式子,所以不用判断,即此依赖集的最小依赖集:
F={A→B,B→C}F=\{A\rightarrow B,B\rightarrow C\} F={A→B,B→C}

求解正则覆盖

其实正则覆盖只是在最小依赖集最后多加了一步合并。因为正则覆盖有定义:

FFF 中不可以存在两个依赖 α1→β1,α2→β2\alpha_1\rightarrow \beta_1,\alpha_2\rightarrow \beta_2α1​→β1​,α2​→β2​,满足 α1=α2\alpha_1=\alpha_2α1​=α2​

  • 例五:求解下列依赖集的正则覆盖

Example:GivenR,R={A,B,C,D,E},F={A→BC,BCD→E,B→D,A→D,E→A}Example:Given \R,R=\{A,B,C,D,E\},F=\{A\rightarrow BC,BCD\rightarrow E,B\rightarrow D,A\rightarrow D,E\rightarrow A\} Example:GivenR,R={A,B,C,D,E},F={A→BC,BCD→E,B→D,A→D,E→A}

解:

前面还是按照求解最小依赖集的方式。

第一步右部化为单属性,经过分解后上述依赖集就变成如下依赖集:
F={A→B,A→C,BCD→E,B→D,A→D,E→A}F=\{A\rightarrow B,A\rightarrow C,BCD\rightarrow E,B\rightarrow D,A\rightarrow D,E\rightarrow A\} F={A→B,A→C,BCD→E,B→D,A→D,E→A}
第二步判断是否有多余依赖式。可以发现式子 A→DA\rightarrow DA→D 是多余的,所以删除。此时依赖集:
F={A→B,A→C,BCD→E,B→D,E→A}F=\{A\rightarrow B,A\rightarrow C,BCD\rightarrow E,B\rightarrow D,E\rightarrow A\} F={A→B,A→C,BCD→E,B→D,E→A}

第三步判断冗余属性,我们只需要判断 BCD→EBCD\rightarrow EBCD→E 即可,可以得到属性 DDD 是多余的,所以去除。得到最小依赖集:
F={A→B,A→C,BC→E,B→D,E→A}F=\{A\rightarrow B,A\rightarrow C,BC\rightarrow E,B\rightarrow D,E\rightarrow A\} F={A→B,A→C,BC→E,B→D,E→A}
根据正则覆盖的定义,需要把 A→B,A→CA\rightarrow B,A\rightarrow CA→B,A→C 合并,最后的正则覆盖:
F={A→BC,BC→E,B→D,E→A}F=\{A\rightarrow BC,BC\rightarrow E,B\rightarrow D,E\rightarrow A\} F={A→BC,BC→E,B→D,E→A}

候选码的应用

候选码的计算

如何快速选出候选码?我总结了一个方法:

  1. 先找入度为0的属性,即从未出现在闭包依赖式右部的属性(做了挺多题的,发现至少都能找到一个)
  2. 判断它的闭包是否为 UUU(即闭包是否包含全属性)
  3. 如果能,此属性就是候选码。如果不能,就继续在此属性上添加属性,知道找到闭包为 UUU 为止(此时说的为止是指以当前找到的候选码长度为标准,意思就是说我找到了一个长度为3的候选码,我要接着判断有没有其他长度为3的也是候选码,全部找完就可以,因为候选码是最小的超码)

还是有点抽象哈,举例子。

  • 例六:求下述依赖集的候选码

Example:GivenR,R={A,B,C,D},F={AB→C,AC→BD}Example:Given \R,R=\{A,B,C,D\},F=\{AB\rightarrow C,AC\rightarrow BD\} Example:GivenR,R={A,B,C,D},F={AB→C,AC→BD}

解:

首先看从未再依赖式右部出现的属性为 AAA,所以先看 (A)+={A}≠U(A)^+=\{A\}\neq U(A)+={A}​=U,所以 AAA 不是候选码,然后逐一添加属性,判断 (AB)+={ABCD}=U(AB)^+=\{ABCD\}= U(AB)+={ABCD}=U,所以 ABABAB 是候选码,接着判断 (AC)+={ABCD}=U(AC)^+=\{ABCD\}= U(AC)+={ABCD}=U,所以 ACACAC 也是候选码,最后 (AD)+={AD}≠U(AD)^+=\{AD\}\neq U(AD)+={AD}​=U,所以 ADADAD 不是候选码。

此时就不用添加属性了,因为已经是长度最小了。所以此依赖集的候选码集合就是 {AB,AC}\{AB,AC\}{AB,AC}

判断范式

1NF、2NF、3NF、BCNF的概念书上都有,不做过多解释了,我自己也看不懂那个杀软定义(

那么要如何判断一个关系模式是几范式呢?

背景

现在给出关系模式和函数依赖(functional dependency,简称FD)集,判断关系模式的所属范式

方法

  1. 求候选码,确定主属性和非主属性(有关主属性以及非主属性,参考候选码、超码等码的概念)。
  2. 判断是否有非平凡FD(依赖式左部不含候选码)
    • 没有,则是BCNF
    • 有非平凡FD
      • 若这些FD的右部都是主属性,则是3NF
      • 若不存在非主属性对码的部分依赖,即任何候选码的任何真子集都不确定非主属性,则是2NF
      • 否则是1NF(判断属性的域是否为原子性,一般都是的…)

概括

抽象,所以看例子

例七:判断下述依赖集是什么范式
Example:GivenR,R={B,C,D,E,G,H},F={BCD→EGH,E→D,G→C}Example:Given \R,R=\{B,C,D,E,G,H\},F=\{BCD\rightarrow EGH,E\rightarrow D,G\rightarrow C\} Example:GivenR,R={B,C,D,E,G,H},F={BCD→EGH,E→D,G→C}
解:

求候选码 BCD、BCE、BDG、BEGBCD、BCE、BDG、BEGBCD、BCE、BDG、BEG,可得主属性 B、C、D、E、GB、C、D、E、GB、C、D、E、G,非主属性 HHH

可得非平凡FD:E→D,G→CE\rightarrow D,G\rightarrow CE→D,G→C,所以不是BCNF

又因为非平凡FD的右边属性都是主属性,所以是3NF

例八:判断下述依赖集是什么范式
Example:GivenR,R={A,B,C,D},F={AB→C,C→D}Example:Given \R,R=\{A,B,C,D\},F=\{AB\rightarrow C,C\rightarrow D\} Example:GivenR,R={A,B,C,D},F={AB→C,C→D}
求候选码 ABABAB,可得主属性 A、BA、BA、B,非主属性 C、DC、DC、D

可得非平凡FD:C→DC\rightarrow DC→D,所以不是BCNF

又因为非平凡FD的右边属性不是主属性,所以不是3NF

接下来判断是否为2NF。根据定义,2NF不存在非主属性对码的部分依赖(关于部份依赖,详见平凡依赖,非平凡依赖,完全依赖,部分依赖,传递依赖,直接依赖的区别 )。所以我们先构造完整依赖,判断依赖函数是否存在冗余属性,如果有就说明不满足不存在部份依赖,不为2NF。

只能对此题。构造非主属性对候选码的完整依赖 AB→C,AB→DAB\rightarrow C,AB\rightarrow DAB→C,AB→D,判断冗余属性(最小依赖集是不是用过呢?),可得两个依赖函数都没有冗余属性,即不存在非主属性对候选码的部份依赖,都是完全依赖,即符合2NF。

参考

求最小依赖集方法

数据库规范化理论大题考点

如何判断范式(1NF、2NF、3NF、BCNF)

相关内容

热门资讯

中国银行招标结果:中国银行北京... 证券之星消息,根据天眼查APP-财产线索数据整理,中国银行股份有限公司5月24日发布《中国银行北京庄...
原创 A... "上下同欲者胜。"——《孙子兵法》 “厂家那边又逼我压两百万的货,可库存早都冒了。” 凌晨两点...
原创 “... 全款买房”和贷款30年,差别到底有多大?曹德旺一句话点醒了很多人 前阵子,一个朋友把看了半年的房子终...
云英谷科技登陆港交所:AI终端... 5月27日,云英谷科技股份有限公司(股票简称:云英谷科技,股票代码:3310.HK)成功登陆港交所主...
京东集团与三一集团签订战略合作... 5月25日,京东集团与三一集团在北京签署战略合作协议。京东集团SEC副主席、京东集团CEO许冉与三一...
青岛的朋友看过来:黄金回收我跑... 前阵子想把家里一些旧金饰处理掉,在青岛问了几家回收黄金的地方。今天就跟大家随便聊聊我打听、上门、对比...
武汉有闲置贵重金属变现需求该怎... 不少有黄金回收需求的用户不知道该如何挑选合适的服务机构,其实只要从资质、专业度、服务能力、口碑几个维...
业绩再度下滑,石药集团一季度归... 图片来源:视觉中国 蓝鲸新闻5月27日讯(记者 屠俊)5月27日午间,石药集团(01093.HK)公...
蚂蚁CEO韩歆毅:在Agent... 【CNMO科技消息】近日,蚂蚁集团CEO韩歆毅在演讲中,系统分享了关于智能体经济和AI支付的底层思考...
Buff叠满!芯片,双重利好!... 芯片领域,传来两则大消息! 一是5月27日有媒体报道称,台积电3纳米制程下半年将涨价15%,明年或再...
“全球正面临第五次油价冲击” 日本央行行长植田和男27日在东京说,自上世纪70年代以来,全球多次经历能源价格急剧上涨,当前全球正面...
白酒股,直线拉升!600779... 【导读】白酒股终于涨了 中国基金报记者 泰勒 大家好,花有重开日,人无再少年。就在刚刚,低迷许久的“...
河北地区闲置名酒如何合规变现 闲置名酒处置的行业现状 近年来随着居民酒类收藏意识的逐步提升,不少家庭都存有不同品类的年份名酒,当...
重磅!长鑫科技科创板IPO获通... 5月27日消息,长鑫科技科创板IPO获上交所上市委会议通过。
东方基金开展“一司一省一高校”... 为深入贯彻落实新“国九条”以及《推动公募基金高质量发展行动方案》的核心要求,积极响应证监会对于金融机...
那句「都是卖猪食的」,为什么你... 你大概也笑了一下。 最近有句话在网上传疯了,说字节的副总裁回怼腾讯的“短视频像猪食”,撂了一句“都是...
2026 年小红书多账号管理工... 摘要 2026 年小红书矩阵运营成品牌获客主流,但账号风控严、消息分散、转化低效等痛点突出。本文基...
打着高知女性旗号割韭菜,“五个... 出品丨搜狐财经 作者丨柴鑫洋 编辑丨李文贤 你被“五个女博士”种草过吗? 打着高知女性旗号,却做着低...
A股董责险渗透率破32%,海南... 开栏语: 保险是经济的“减震器”,但保险条款复杂晦涩,犹如海下暗礁。 即日起,海财经·证券导报开设“...
奥尼电子:49万股限制性股票将... 5月27日,奥尼电子(301189)发布公告,2025年限制性股票激励计划第一个归属期归属结果已确定...