数据库设计的范式

数据库设计的范式

  概念 设计数据库时 需要遵循的一些规范

  设计关系数据库时 遵从不同的规范要求 设计除合理的关系型数据库 这些不同的规范要求被成为不同的范式 各种范式呈递次规范 越高范式数据库冗余越小

  目前关系数据库的有六种范式:第一范式(INF),第二范式(2NF), 第三范式(3NF),巴斯-科德范式(BCNF),第四范式(4NF),和,第五范式(5NF,又称完美范式)

第一范式(1NF):每一列都是不可分割的原子数据项

第二范式(2NF):在1NF的基础上,非码属性必须完全依赖于码(在1NF基础上消除非主属性对主码的部分函数依赖)

  几个概念:

  函数依赖:A-->B,如果通过A属性(属性组)的值,可以确定唯一B属性的值。则称B依赖于A

、  - -列如:学号-->姓名。(学号,课程名称)-->分数'

  完全函数依赖:A-->B 如果A是一个属性组 则B属性值得确定值需要依赖A属性组中所有的属性值

    - -列如:(学号,课程名称) -->分数

  部分函数依赖:A-->B 如果A是一个属性组,则B属性值得确定只需要依赖A属性组中某一些值即可

   - -列如:(学号,课程名称)-->姓名

  传递函数依赖:A-->B,B-->C,如果通过A属性(属性组)的值,可以确定唯一b属性的值 在通过B属性(属性组)的值可以确定唯一C

  属性的值则称,C传递函数依赖与A

   - -列如:学号-->系名,系名-->系主任

  码:如果在一张表中,一个属性或属性组,被其他所有属性所完全依赖,则称这个属性(属性组)为该表的码

   - -列如 该表中码为:(学号,课程名称)

   - -主属性:码属性组中的所有属性

   - -非主属性:除过码属性组的属性

第三范式(3NF):在2NF基础上 任何非主属性不依赖于它非主属性(在2NF基础上消除传递依赖)

posted @   帕拉利斯  阅读(25)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
点击右上角即可分享
微信分享提示