数据库中的函数依赖的完全函数依赖和部分函数依赖还有传递函数依赖怎么理解

首页 / 常见问题 / 低代码开发 / 数据库中的函数依赖的完全函数依赖和部分函数依赖还有传递函数依赖怎么理解
作者:低代码开发工具 发布时间:24-10-25 13:58 浏览量:8096
logo
织信企业级低代码开发平台
提供表单、流程、仪表盘、API等功能,非IT用户可通过设计表单来收集数据,设计流程来进行业务协作,使用仪表盘来进行数据分析与展示,IT用户可通过API集成第三方系统平台数据。
免费试用

数据库中的函数依赖的完全函数依赖:表示属性的值只和另一个属性或属性集合有关。部分函数依赖:表示属性的值取决于多个属性,而且其中一些属性可以被移除而不影响该属性的值。传递函数依赖:表示属性的值由其他属性之间通过传递关系所决定。

一、数据库中的函数依赖

在关系型数据库中,函数依赖是指一个或多个属性(列)值的变化是否会导致其他属性(列)值的变化。根据不同的依赖关系类型,可以分为以下几种:

1、完全函数依赖

表示属性的值只和另一个属性或属性集合有关,任何其他属性没有影响力。

设X,Y是关系R的两个属性集合,X’是X的真子集,存在X→Y,但对每一个X’都有X’!→Y,则称Y完全函数依赖于X。

比如说:C可以通过AB得到,并且C不可以仅通过A得到,也不可以仅通过B得到,那么就说C完全依赖AB。

实例:通过{学生学号,选修课程名}可以得到{该生本门选修课程的成绩},而通过单独的{学生学号}或者单独的{选修课程名}都无法得到该成绩,则说明{该生本门选修课程的成绩}完全依赖于{学生学号,选修课程名}

2、部分函数依赖

表示属性的值取决于多个属性,而且其中一些属性可以被移除而不影响该属性的值。

设X,Y是关系R的两个属性集合,存在X→Y,若X’是X的真子集,存在X’→Y,则称Y部分函数依赖于X。

比如说:C可以通过AB得到,并且C也可以仅通过A得到,仅通过B得到,那么就说C部分依赖AB。

实例:通过{学生学号,课程号}可以得到{该生姓名},而通过单独的{学生学号}已经能够得到{该生姓名},则说明{该生姓名}部分依赖于{学生学号,课程号}; 又比如, 通过{学生学号,课程号}可以得到{课程名称},而通过单独的{课程号}已经能够得到{课程名称},则说明{课程名称}部分依赖于{学生学号,课程号}。(部分依赖会造成数据冗余及各种异常。)

3、传递函数依赖

表示属性的值由其他属性之间通过传递关系所决定。

设X,Y,Z是关系R中互不相同的属性集合,存在X→Y(Y !→X),Y→Z,则称Z传递函数依赖于X。

比如说:B可以通过A得到,C可以通过B得到,那么就称C传递依赖A。

实例:在关系R(学号,宿舍,费用)中,通过{学号}可以得到{宿舍},通过{宿舍}可以得到{费用},而反之都不成立,则存在传递依赖{学号}->{费用}。(传递依赖也会造成数据冗余及各种异常。)

二、数据库三大范式

1、名列前茅范式

数据库每一列都是不可分的基本数据项(原子数据项)。

就比如说,下面一个数据表:

上表所示的地址,就不符合名列前茅范式,以为地址那一列可以分为省份和市区,故可以修改为:

2、第二范式

第二范式要求在满足名列前茅范式的基础上,非码属性必须完全依赖于候选字,也就是要消除部分依赖。

就比如说:

如上图加粗字体所示,可能对于同一个订单,含有不同的产品,因此主键必须是产品号和订单号联合组成。但可以发现产品数量、产品价格与订单号、产品号都有关,不过订单时间与订单金额仅与订单号有关,这就违反了第二范式。故可以修改为:

3、第三范式

第三范式要求在满足第二范式的基础上,任何非主属性不依赖于其他非主属性,即在第二范式的基础上消除传递依赖。第三范式要求数据表的每一列都与主键直接相关,而不是间接相关。

就比如说:

从上表可以看出,所有属性都完全依赖于学号,故符合第三范式,但是班主任性别和班主任年龄直接依赖于班主任姓名,而不是主键学号,故不符合第三范式。可修改为:

延伸阅读1:数据库模式分解简介

  • 把一个关系模式分解成若干个关系模式的过程,称为关系模式的分解。
  • 把低一级的关系模式分解为若干个高一级的关系模式的方法不是少数的。
  • 只有能够保证分解后的关系模式与原关系模式等价,分解方法才有意义。
最后建议,企业在引入信息化系统初期,切记要合理有效地运用好工具,这样一来不仅可以让公司业务高效地运行,还能最大程度保证团队目标的达成。同时还能大幅缩短系统开发和部署的时间成本。特别是有特定需求功能需要定制化的企业,可以采用我们公司自研的企业级低代码平台织信Informat。 织信平台基于数据模型优先的设计理念,提供大量标准化的组件,内置AI助手、组件设计器、自动化(图形化编程)、脚本、工作流引擎(BPMN2.0)、自定义API、表单设计器、权限、仪表盘等功能,能帮助企业构建高度复杂核心的数字化系统。如ERP、MES、CRM、PLM、SCM、WMS、项目管理、流程管理等多个应用场景,全面助力企业落地国产化/信息化/数字化转型战略目标。 版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们微信:Informat_5 处理,核实后本网站将在24小时内删除。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系邮箱:hopper@cornerstone365.cn 处理,核实后本网站将在24小时内删除。

最近更新

团队技术研发流程表怎么做
01-17 18:02
怎么改造研发团队研发流程
01-17 18:02
如何优化研发流程以缩短产品上市时间
01-17 18:02
研发流程团队 职责是什么
01-17 18:02
软件传统研发流程包括什么
01-17 18:02
研发流程用什么软件做
01-17 18:02
低代码后台:《低代码后台开发指南》
01-17 17:28
Vue 3.0低代码开发平台:《Vue 3.0低代码平台》
01-17 17:28
国内最强低代码开发平台:《国内顶尖低代码平台》
01-17 17:28

立即开启你的数字化管理

用心为每一位用户提供专业的数字化解决方案及业务咨询

  • 深圳市基石协作科技有限公司
  • 地址:深圳市南山区科技中一路大族激光科技中心909室
  • 座机:400-185-5850
  • 手机:137-1379-6908
  • 邮箱:sales@cornerstone365.cn
  • 微信公众号二维码

© copyright 2019-2024. 织信INFORMAT 深圳市基石协作科技有限公司 版权所有 | 粤ICP备15078182号

前往Gitee仓库
微信公众号二维码
咨询织信数字化顾问获取最新资料
数字化咨询热线
400-185-5850
申请预约演示
立即与行业专家交流