前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MySQL数据库范式

MySQL数据库范式

作者头像
用户9645905
发布2023-04-04 09:16:18
4400
发布2023-04-04 09:16:18
举报
文章被收录于专栏:Linux学习~

文章目录

MySQL数据库范式

1、范式的优缺点

  • 应用数据库范式的好处:
  1. 减少数据冗余(这是最主要的好处,其他好处都是由此而附带的)
  2. 消除异常(插入异常,更新异常,删除异常)
  3. 让数据组织的更加和谐
  • 范式设计的缺点:
  1. 范式越高,意味着表越多,多表联合查询的机率就越大,SQL的效率就变低
  2. 表越多时,在做更新、删除、插入数据时需要维护的表越多,同样会降低数据库的效率
  • 因此:

并不是应用的范式越高越好,视实际情况而定。第三范式已经很大程度上减少了数据冗余,并且基本预防了数据插入异常,更新异常,和删除异常了

2、第一范式

  • 第一范式: 每一列保持原子特性

列都是基本数据项,不能够再进行分割,否则设计成一对多的实体关系

注:不符合第一范式不能称作关系型数据库

  • 例如:表中的地址字段,可以再细分为省,市,区等不可再分割(即原子特性)的字段
image-20230402155256582
image-20230402155256582

3、第二范式

  • 第二范式:属性完全依赖于主键-主要针对联合主键

非主属性完全依赖于主关键字,如果不是完全依赖主键(即不全依赖联合主键中的所有关键字),应该拆分成新的实体,设计成一对多的实体关系

  • 例如:选课关系表为SelectCourse(学号, 姓名, 年龄, 课程名称, 成绩, 学分),(学号,课程名称)是联合主键,但是学分字段只和课程名称有关,和学号无关,相当于只依赖联合主键的其中一个字段,不符合第二范式。
image-20230402155938670
image-20230402155938670

4、第三范式

  • 第三范式:属性不依赖于其它非主属性

要求一个数据库表中不包含已在其它表中已包含的非主关键字信息

注:一般关系型数据库满足第三范式就可以了

  • 示例:学生关系表为Student(学号, 姓名, 年龄, 所在学院, 学院地点, 学院电话),学号是主键,但是学院电话只依赖于所在学院,并不依赖于主键学号,因此该设计不符合第三范式,应该把学院专门设计成一张表,学生表和学院表,两个是一对多的关系。
image-20230402160031563
image-20230402160031563

5、BC范式

  • BC范式:每个表中只有一个候选键

BC范式是在第三范式的基础上的一种特殊情况,即每个表中只有一个候选键(在一个数据库中每行的值都不相同,则可称为候选键)

  • 示例:每一个员工的email都是唯一的(不可能两个人用同一个email),则此表不符合BC范式,对其进行BC范式化后的关系图为
image-20230402160445855
image-20230402160445855
  • 注意:

在要求更好的查询效率时,可以不遵循BC范式(多一个候选键,就多一份表,更多可能需要进行联合查询),候选键储存在主表上也是没有问题的,并不会造成数据的冗余,在一定程度上提高查询效率

6、第四范式

  • 第四范式:消除表中的多值依赖(减少维护数据一致性的工作)

比如:noNF表中的skill技能这个字段,有的人是“java,mysql”,有的人描述的是“Java,MySQL”,这样数据就不一致了,解决办法就是将多值属性放入一个新表

image-20230402160219439
image-20230402160219439

样数据就不一致了,解决办法就是将多值属性放入一个新表

[外链图片转存中…(img-n7yeQkem-1680516329350)]

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2023-04-03,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 文章目录
  • MySQL数据库范式
    • 1、范式的优缺点
      • 2、第一范式
        • 3、第二范式
          • 4、第三范式
            • 5、BC范式
              • 6、第四范式
              相关产品与服务
              云数据库 MySQL
              腾讯云数据库 MySQL(TencentDB for MySQL)为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。其具备6大企业级特性,包括企业级定制内核、企业级高可用、企业级高可靠、企业级安全、企业级扩展以及企业级智能运维。通过使用腾讯云数据库 MySQL,可实现分钟级别的数据库部署、弹性扩展以及全自动化的运维管理,不仅经济实惠,而且稳定可靠,易于运维。
              领券
              问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档