news 2026/6/23 14:42:17

数据库范式

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
数据库范式

范式

数据库范式是一组规则。在设计关系型数据库的时候,遵从不同的规范要求,设计出合理的关系型数据库,这些不同的规范要求被称为不同的范式。
关系型数据库有六种范式:第一范式(1NF),第二范式(2NF),第三范式(3NF),巴斯-科得范式(BCNF),第四范式和第五范式。越高的 范式数据库冗余越小。普遍人文范式越高虽然对数据关系有更好的约束性,但也可能导致数据库IO更繁忙,因此,在实际应用中,数据库设计通常只需要满足第三范式即可。

第一范式

  • 数据库表的每一列都是不可分割的原子数据项,而不是集合,数组,对象等非原子数据
  • 在关系型数据库的设计中,满足第一范式是对关系模式的要求。不满足的数据库不能成为关系型数据库
    示例
    定义一个学生表,需要记录学生信息和 学校信息
    反例

    这个学校是你可以继续拆分的,所以这不满足第一范式
    正例

    尽管他很丑陋,但是确实是满足第一范式
    在关系型数据库中,每一列都可以用基本数据类型表示,天然满足第一范式

第二范式

在满足第一范式的基础上,不存在非关键字对任意候选键部分函数依赖。存在于表中定义了复合主键的情况。

候选键:可以唯一标识一行数据的列或者列的组合,可以从候选键中选一个或者多个当做表的主键

反例

  • 这张表是使用学号+课程名定义复合索引唯一标识一个学生某门课程的乘积,这也是这张表的主要作用
  • 学生是通过学号来确定的,学生的年龄、性别和课程没有关系,只依赖学号,不依赖课程名;学分是通过课程确定的,课程的学生和学生没有关系,学分只依赖课程名,不依赖学生;乘积同时依赖学号+课程名
  • 对于使用符合主键的表,如果一行数据中有些列至于复合主键中一个或者其中几个列有关,那么就说他存在部分函数依赖,不满足第二范式
    正例
  • 设计表:针对需求应该设计三张表,学生表、课程表和成绩表



第二范式强调的是部分函数依赖,当一张表中的主键只有一列时,天然满足第二范式

不满足第二范式可能出现的问题

  1. 数据冗余
    比如反例中的,学生的姓名、年龄、性别和课程学分重复出现,造成了大量的数据冗余。
  2. 更新异常
    如果要调整MySQL的学分,那么就需要更新表中所有关于MySQL课程的记录,一旦执行终端导致某些记录更新成功,某些更新失败,就会造成一门课程出现不同学分的情况,数据不一致的问题。
  3. 插入异常
    目前这样设计,成绩和每一门课和学生都有关系,也就是说学生参加选修课程考试取得成绩之后才能生成一条记录。当有一门新课还没有学生参加考试取得成绩之前,这么新课在数据库中是不存在的,因为成绩为空的记录没有意义。
  4. 删除异常
    把毕业学生的考试数据全都删除,此时课程和学分的信息也会被删除掉,有可能导致一段时间内,数据库里没有某门课程和学分的信息。

第三范式

在满足第二范式的基础上,不存在非关键字段,对任意候选键的传递依赖

反例

  • 因为要描述的是学生信息,并且在表中定义了ID,ID可以明确的标识每条学生信息
  • 在这个表结构中,可以看出学生的学号、姓名、年龄、性别和主键ID强相关;学院的电话和学院也是强相关;在一个表中出现了两个强相关的关系,而且这两个强相关关系又存在传递现象——通过学生ID可以找到学生记录,学生记录中包含学院名,每个学院又有自己的电话和地址。
    正例


    需要查询的时候,只需要让学生表和学员表通过学院ID进行连接即可。此时所有的表满足第三范式。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/23 15:51:05

PMP考证三本书,实际就200条考点,小白一次过!

2026年7月PMP又要改版啦,新增图形题跟案例题,难度飙升,各位备考的友友抓紧时间考3月跟6月的考试吧,目前的考纲参考教材三本书,考点归纳起来也就200条考点,小白不用担心,跟着学上岸很容易&#x…

作者头像 李华
网站建设 2026/6/22 16:50:38

.NET运行时核心仓库的治理架构解析:责任分配与协作机制

核心协作机制标签系统与通知机制文档明确了 Pull Request 和 Issue 的标签策略:当需要在问题或 PR 中标记相关人员时,应该标记区域责任人(Owners)而非领导者(Lead)。这种设计体现了扁平化的协作理念&#x…

作者头像 李华
网站建设 2026/6/19 2:49:39

中科大团队揭秘一分钟高清视频的生成秘诀

这项由中国科学技术大学的贾维南、黄孟琦团队与字节跳动FanqieAI、香港科技大学、武汉大学等机构联合完成的研究,于2025年10月22日发表在arXiv预印本平台,论文编号为arXiv:2510.18692v1。有兴趣深入了解的读者可以通过该编号查询完整论文。这项研究首次实…

作者头像 李华
网站建设 2026/6/24 6:56:41

研究人员利用300万天Apple Watch数据训练疾病检测AI

当Yann LeCun还担任Meta首席AI科学家时,他提出了联合嵌入预测架构(JEPA),这一架构本质上是教导AI推断缺失数据的含义,而非数据本身。换句话说,当处理数据空白时,模型学习预测缺失部分所代表的含…

作者头像 李华
网站建设 2026/6/23 2:14:18

西湖大学与清华TwinFlow:AI图像生成效率提升百倍

这项由西湖大学、清华大学、浙江大学和包容AI公司联合完成的研究发表于2025年12月的arXiv预印本服务器,论文编号为arXiv:2512.05150v1。研究团队由程正林、孙鹏、李建国和林涛等多位学者组成,其中林涛教授为通讯作者。有兴趣深入了解的读者可以通过论文编…

作者头像 李华