博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
数据库设计的三大范式通俗解释
阅读量:4678 次
发布时间:2019-06-09

本文共 811 字,大约阅读时间需要 2 分钟。

一、三大范式通俗解释:

(1)简单归纳:

  第一范式(1NF):字段不可分;

  第二范式(2NF):有主键,非主键字段依赖主键;
  第三范式(3NF):非主键字段不能相互依赖。

(2)解释:

  1NF:原子性。 字段不可再分,否则就不是关系数据库;;

  2NF:唯一性 。一个表只说明一个事物;
  3NF:每列都与主键有直接关系,不存在传递依赖。

二、例子说明

  (1)不符合第一字段的例子

                                                                             表:字段1, 字段2(字段2.1,字段2.2), 字段3

字段2可以拆分成字段2.1和字段2.2,不符合第一范式。
  (2)不符合第二范式的例子 
                                                                            表:学号, 姓名, 年龄, 课程名称, 成绩, 学分 
这个表明显说明了两个事务:学生信息, 课程信息。

  1)存在以下问题:

                               a、数据冗余:每条记录都含有相同信息; 

                               b、删除异常:删除所有学生成绩,就把课程信息全删除了; 
                               c、插入异常:学生未选课,无法记录进数据库; 
                               d、更新异常:调整课程学分,所有行都调整。
  2)修正:
                               学生表:学号, 姓名, 年龄 

                               课程表:课程名称,学分     

                               选课关系表:学号, 课程名称, 成绩

  (3)不符合第二范式的例子 

                                                                         表:学号, 姓名, 年龄, 所在学院, 学院联系电话

其中关键字为单一关键字"学号"。存在依赖传递::(学号) → (所在学院) → (学院联系电话) 。

  1)存在问题::

      a、数据冗余:有重复值; 
      b、更新异常:有重复的冗余信息,修改时需要同时修改多条记录,否则会出现数据不一致的情况 
      c、删除异常 
  2)修正: 
                      学生表:学号, 姓名, 年龄, 所在学院;
                      学院表:学院, 电话 
整理自:https://www.zhihu.com/question/24696366

 

转载于:https://www.cnblogs.com/hezhiyao/p/7407468.html

你可能感兴趣的文章
使用Flickr的图片拼出你的句子
查看>>
Visual Studio中web应用程序和网站区别
查看>>
浅析/dev/shm
查看>>
BZOJ4010 HNOI2015 菜肴制作 拓扑排序+贪心
查看>>
处理打拼音时触发input事件bug
查看>>
074-PHP数组元素相乘
查看>>
Android性能调优篇之UI布局优化
查看>>
DateUtils
查看>>
Java -- IO -- 目录
查看>>
三路快速排序
查看>>
不能出现W3!!
查看>>
【Linux笔记(002) 】-- centos7 文档操作基本命令
查看>>
【算法总结】动态规划-背包问题
查看>>
EF性能优化
查看>>
网络流24题——试题库问题
查看>>
数据挖掘:周期性分析SMCA算法
查看>>
Linux下查看文件编码及批量修改编码
查看>>
大疆回应无人机数据安全风险质疑
查看>>
myeclipse格式化代码换行的问题
查看>>
在IIS下部署PHP
查看>>