数据库的第三范式是什么意思?

数据库的第三范式是什么意思?,第1张

第三范式指数据库中不能存在传递函数依赖关系。

简而言之, 第三范式( 3NF) 要求一个数据库表中不包含已在其它表中已包含的非主关键字信息。

所以第三范式具有如下特征:

1, 每一列只有一个值

2, 每一行都能区分。

3, 每一个表都不包含其他表已经包含的非主关键字信息。

例如, 帖子表中只能出现发帖人的 id, 而不能出现发帖人的 id, 还同时出现发帖人姓名,

否则, 只要出现同一发帖人 id 的所有记录, 它们中的姓名部分都必须严格保持一致, 这就是数据冗余。

三范式:

①第一范式:数据库表的每一列都是不可分割的基本数据项,同一列中不能有多个值,即实体中的某个属性不能有多个值或者不能有重复的属性存在传递函数依赖关系。

②第二范式:完全依赖于主键,消除非主属性对主码的部分函数依赖。

③第三范式:每个非关键字列都独立于其他非关键字列,并依赖于关键字,第三范式指数据库中不能。

注意事项:

1、数据冗余:同一门课程由n个学生选修,"学分"重复n-1次,同一个学生选修了m门课程,姓名和年龄重复m-1次。

2、更新异常:若调整了某门课程的学分,数据表中所有行的"学分"值都需要更新,否则会出现同一门课程学分不同的情况。

3、插入异常:假设要开一门新课程,暂时没有人选修,那么由于没有"学号"关键字,"课程"与"学分"也无法记录入数据库。

4、删除异常:假设一批学生已经完成课程的选修,这些选修记录就应该从数据库表中删除。但是,与此同时,"课程"和"学分"也被删除了,显然,这最终可能会导致插入异常。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9242359.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-26
下一篇 2023-04-26

发表评论

登录后才能评论

评论列表(0条)

保存