数据库函数依赖

数据库函数依赖数据库函数依赖一、函数依赖(FunctionalDependency)的概念      数据依赖的一种,它反映属性或属性组之间相依存,互相制约的关系,即反映现实世界的约束关系。二、定义    设R(U)是属性U上的一个关系模式,X和Y均为U={A1,A2,…,An}的子集,r为R的任一关系,如果对于r中的任意两个元组u,v,只要有u[X]=v[X],就有u

大家好,又见面了,我是你们的朋友全栈君。

一、函数依赖(Functional Dependency)的概念 
     
数据依赖的一种,它反映属性或属性组之间相依存,互相制约的关系,即反映现实世界的约束关系。

二、定义 
   
RU)是属性U上的一个关系模式,XY均为U={A1A2An}的子集,rR的任一关系,如果对于r中的任意两个元组uv,只要有u[X]=v[X],就有u[Y]=v[Y],则称X函数决定Y,或称Y函数依赖于X,记为XY 
例:
(sno-
学生IDtno-教师IDcno-课程IDsname-学生姓名,tname-教师姓名,cname-课程名称,grade-成绩)
1
snosname, cnocname,(sno,cno)grade √
2
snamesno, tnocno, snotname ×

三、函数依赖是语义范畴 
1
、语义:数据所反映的现实世界事物本质联系
2
、根据语义来确定函数依赖性的存在与否
3
、函数依赖反映属性之间的一般规律,必须在关系模式下的任一个关系r中都满足约束条件。

四、属性间的联系决定函数依赖关系 
XY均是U的子集
1
XY间联系是1:1,则XY,YX。(相互依赖,可记作X←→Y
2
XY间联系是M:1(M)XY
3
XY间联系是M:N(M,N),则XY间不存在函数依赖。

五、完全函数依赖和部分函数依赖 
1
、函数依赖分为完全函数依赖和部分函数依赖
2
、定义:
  
R(U)中,如果XY,并且对于X的任何真子集X’都有X’Y’,则称Y完全依赖于X,记作XY;否则,如果XY,且X中存在一个真子集X’,使得X’Y成立,则称Y部分依赖于X
例:
学生ID,学生姓名,所修课程ID,课程名称,成绩
(学生ID,所修课程ID成绩
成绩既不能单独依赖于学生ID,也不能单独依赖于所修课程ID,因此成绩完全函数依赖于关键字。
(学生ID,所修课程ID学生姓名
学生ID学生姓名
学生姓名可以依赖于关键字的一个主属性——学生ID,因此学生姓名部分函数依赖于(学生ID,所修课程ID)。

六、平凡函数依赖和非平凡函数依赖 
   
XY均为某关系上的属性集,且XY
    1)
Y包含于X,则称XY为:平凡函数依赖;(Sno, Cno) Sno  (Sno, Cno) Cno
    2)
Y不包含于X,则称XY为:非平凡函数依赖。(Sno, Cno) Grade
     Y
包含于X内,WX相交,与Y无直接交集。 
    
则:XY为平凡函数依赖
     X
W, WY为非平凡函数依赖

七、传递函数依赖 XYYZ Z传递函数依赖于X

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/148206.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 了解图形数据库_图形数据库neo4j

    了解图形数据库_图形数据库neo4j企业架构师应该知道什么您在Google上获得的图表数据库的描述主要是学术性的。我看到很多关于图形数据库的描述,它们讨论了Königsberg的七座桥梁或互联网的发明者Berners-Lee。有理论和愿景很好,但对我来说,我仍然认为引导相关性很重要。为什么图形数据库对您很重要?想象一下存储在当地连锁餐厅的数据。如果您要跟踪,则将客户信息存储在一个数据库表中,将您提供的项目存储在另一个数据…

    2025年6月27日
    4
  • 李开复:人工智能时代怎样才不会被取代_李开复关于人工智能的演讲

    李开复:人工智能时代怎样才不会被取代_李开复关于人工智能的演讲提起“人工智能”你会想到什么?  是欧美大片里战无不胜、技能完备的人形机器人? 还是与柯洁等围棋名将上演惊世对决的AlphaGo?事实上人工智能并没有那么遥远 “比爱人还爱你”的手机…… 你每天晨起打开的电子新闻报…… 自动驾驶汽车或翻译软件…… 人工智能早已渗透在我们生活的每一个角落——它,无处不在。

    2022年9月29日
    3
  • JAVA校园二手交易平台

    JAVA校园二手交易平台本系统主要面向于大学校园网用户,依托校园网提供给这些用户一个发布和交流二手商品信息的平台。在大学校园里,存在着很多的二手商品,但是由于信息资源的不流通以及传统二手商品信息交流方式的笨拙,导致了很多仍然具有一定价值或者具有非常价值的二手商品的囤积,乃至被当作废弃物处理。现在通过校园网进入到本系统,可以方便快捷的发布和交流任何二手商品的信息,并且可以通过留言方式进行深一步的交流。由于每个大学的校园网都…

    2022年6月15日
    25
  • Location hash 属性

    Location hash 属性hash属性是一个可读可写的字符串,该字符串是URL的锚部分(从#号开始的部分)。实例返回一个URL的主要部分。假设当前的URL是http://www.runoob.com/test.htm#PART2document.write(location.hash);以上实例输出结果:#part2…

    2022年7月13日
    19
  • docker flask_sqlallochandle on sql_handle

    docker flask_sqlallochandle on sql_handleFlask-SQLAlchemy-config一、配置键SQLALCHEMY_DATABASE_URI#连接数据的数据库SQLALCHEMY_DATABASE_URI=’sqlite:////tmp/test.db’SQLALCHEMY_DATABASE_URI=’mysql://username:password@server/db’#SQLAlchemy把一个引擎的源表示为一个连同设定引擎选项的可选字符串参数的URI。URI的形式是:dialect+driver://userna

    2025年6月2日
    2
  • 最新Java面试题,常见面试题及答案汇总[通俗易懂]

    Java最新面试题、面试题答案汇总

    2022年4月6日
    51

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号