数据库规范化详解:从1NF到BCNF
创作时间:
作者:
@小白创作中心
数据库规范化详解:从1NF到BCNF
引用
CSDN
1.
https://blog.csdn.net/w605283073/article/details/142299213
数据库的规范化是数据库设计中的一个重要过程,旨在减少数据冗余和提高数据一致性。它通过一系列规则(称为范式)来优化数据库表的结构。
常见的范式有1NF、2NF、3NF和BCNF。让我们分别来解释这些范式。
生活化例子
想象你在整理一个家庭成员信息的表格:
- 1NF:每个成员的名字、电话、家庭住址都被记录在一张表里。如果某个成员有多个电话号码或地址,我们可能会直接把这些信息用逗号隔开放在一个单元格中。
- 2NF:你意识到,把多个电话号码或地址放在同一个单元格中很不方便,所以你决定为每个电话号码或地址建立单独的行,但仍保持成员信息的一致性。
- 3NF:后来你发现,不同的成员住在同一个地址,把地址信息在每个成员的记录里重复存储浪费空间。于是你把地址单独存到另一个表中,建立一种引用关系。
- BCNF:当家庭成员的记录变得复杂时,你发现某些成员的信息没有唯一的主键可以标识。你进一步优化表结构,确保每一个信息都有唯一、明确的主键。
概念讲解
- 第一范式 (1NF):
- 1NF的核心是每一个字段只能存储单一的值,不能有重复的列或多值的列。举例来说,在一个联系人信息的表格中,如果某个人有多个电话号码,我们不能把这些电话用逗号分隔后放在一个字段里,而是要为每个电话号码建立单独的行。
- 第二范式 (2NF):
- 2NF要求数据满足1NF,同时每个非主键字段都必须依赖于整个主键。这意味着如果一个表有复合主键(多个字段作为主键),那么每个非主键字段都必须依赖于全部主键,而不是主键的一部分。
- 例如,如果有一个“课程-学生”表,主键是“课程ID+学生ID”,但有一列是“课程名称”,显然这列只依赖于“课程ID”,而不是整个主键。这种情况违反了2NF,需要把课程信息和学生信息分开存储。
- 第三范式 (3NF):
- 3NF在满足2NF的基础上,要求非主键字段不能依赖于其他非主键字段。换句话说,非主键字段只能依赖于主键。
- 比如,有一个“学生-班级”表,主键是“学生ID”,而表中有一列是“班级名称”,另一列是“班主任名字”。因为“班主任名字”依赖于“班级名称”而不是“学生ID”,这种情况违反了3NF,需要将班级信息拆分到一个独立的表中。
- BCNF (Boyce-Codd范式):
- BCNF是3NF的加强版,它更严格地要求表格中每个字段的依赖关系必须依赖于候选键(主键或唯一键)。即使数据已经满足了3NF,如果主键的设计不够合理(如非主键也可以决定其他字段),可能仍会出现数据冗余的问题。
- 举例来说,如果有一个表,包含“教师ID”、“课程ID”和“教师办公室”。可能存在某些情况下,教师ID和课程ID组合并不能唯一决定教师办公室。这时,就需要通过BCNF的规则重新设计表结构,避免这种情况。
简单记法
- 1NF:单元格不能有多值,即“每个格子只能装一个东西”。
- 2NF:部分依赖要拆分,即“字段不能只依赖主键的一部分”。
- 3NF:传递依赖要消除,即“非主键字段不能依赖其他非主键字段”。
- BCNF:候选键规范化,即“任何字段都要唯一依赖主键”。
热门推荐
卷耳虎猫(Tigrett)—最像老虎的宠物猫品种
保护心脑血管,这几种食物你不可不知?
太浪漫了!成都又一绝美花海爆火,外地游客专程来打卡
起诉离婚时如何判断夫妻感情确已破裂?
H110和H81主板的性能和适用性对比
使用丹参片的注意事项有哪些
智慧赋能武汉城市交通高质量发展的实践
C语言rand、srand库函数生成随机数(附时间戳)
GraphPad折线图如何加显著性星号?详细步骤图文解析
精神病司法鉴定机构有哪些
如何判断自己是否属于疤痕体质?有哪些明显的特征可以识别?
哺乳期妈妈想离婚,孩子归属权如何判定?
《马嵬·海外徒闻更九州》的原文及译文鉴赏
印度大壶节:地球上最大的文化聚会
巴尔德成巴萨左路新动力:持球推进助佩德里获空位机会
面向对象编程如何实现代码的复用性
WiFi与Bluetooth技术详解:2.4G与5G频段的差异及应用场景
牙齿整齐但嘴巴前凸怎么矫正?一般是骨骼位置失衡:正畸+正颌协同改善治疗
百万粉丝网红自曝考研成绩:初试412分,北大专业第二
家住楼房如何避震?这份避震指南请收好
烫伤疤痕需要多长时间才能恢复?恢复过程中的注意事项是什么?
走进非遗——探寻武安傩戏
狂飚胶皮使用指南:40+ABS时代,它还有用武之地吗?
空心阴极灯在食品安全和农产品分析中的重要性
这位南开先生,开创中国逻辑史学科!
“海市蜃楼”神秘诡异,其场景地球没有参照物,难道是平行时空?
股票分红后卖出怎么扣税
U盘格式化工具合集:6个免费的U盘格式化工具
还完房贷后怎么查是否解押成功?
RFID标签:驱动托盘流转效率的新引擎