数据库设计三范式

14 篇文章 0 订阅

    所谓数据库设计范式(NF),就是在设计关系型数据库时所遵循的规范要求,以设计出结构简洁,清晰合理的数据库,同时,在操作数据库时不会发生异常

在实际开发过程中我们只需要满足的三个范式:

1.第一范式

第一范式是最基本的范式,要求数据库表中的字段都是单一属性,且不可再分。

例如下表中的学生信息,每项属性必须是单一的,分到不可分为止。

 

2.第二范式

第二范式,数据库表中不存在非关键字段对任一候选关键字段的部分函数依赖。

具体操作就是确保数据库表中的每一列都和主键相关,而不能只与主键的某一部分相关。也就是说一个表中只保存一种数据。

例如上表中,卡和学生是不同的类,就需要把卡和学生的信息分开。

 

卡信息表:


学生信息表:


通过这样设计,在很大程度上减小了数据库的冗余。


建立外键的约束关系:

 

3.第三范式

第三范式:确保每列都和主键列直接相关,而不是间接相关。也就是在满足2NF的基础上,任何非主属性不得传递依赖于主属性。例如表中的UserID

 


    数据库范式的主要目的是为了减少数据冗余,数据冗余产生的本质就是在一个表中存在字段与字段之间的一对多,或者多对多关系。解决这个几对几的关系问题,就能轻易实现满足第三范式的数据库设计。这并意味着不符合范式要求的设计一定是错误的,在数据库表中存在1:1或1:N关系这种较特殊的情况下,合并导致的不符合范式要求反而是合理的。

    在我们设计数据库的时候,一定要时刻考虑范式的要求。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值