MySQL之数据库数据库范式学习笔记(二)

三大范式

范式是数据库设计中的概念,用于规范化数据结构,以减少数据冗余并确保数据的一致性和完整性。MySQL 数据库设计通常遵循一定的范式,其中最常见的是第一至第三范式。以下是各个范式的简要说明:

第一范式(1NF)

  • 每个字段都是原子性的,不可再分。
  • 没有重复的列或分组列。
例子:
订单表(Orders):
OrderID   CustomerName   OrderDate       Item1     Item2     Item3
1         Alice          2022-06-01      Apple     Orange    Banana
2         Bob            2022-06-02      Pear      Pineapple Mango

这个表违反了第一范式,因为Item1Item2Item3应该单独存在于一个子表中。

第二范式(2NF)

  • 数据表中的非主键列完全依赖于全部主键而不是部分主键。
例子:
订单详情表(OrderDetails):
OrderID   ProductID   ProductName   UnitPrice   Quantity
1         101         Apple         1.99        2
1         102         Orange        0.99        3
2         103         Pear          2.49        1
2         104         Pineapple     3.99        2
2         105         Mango         2.99        3

这个表符合第二范式,因为每个非主键列(ProductNameUnitPriceQuantity)都完全依赖于主键(OrderIDProductID)。

第三范式(3NF)

  • 数据表中的非主键列之间互不依赖,而是直接依赖于主键列。
例子:
客户表(Customers):
CustomerID   CustomerName   Email            Address
1            Alice          alice@example    123 Main St
2            Bob            bob@example      456 Elm St

订单表(Orders):
OrderID   CustomerID   OrderDate
1         1            2022-06-01
2         2            2022-06-02

这个设计符合第三范式,因为EmailAddress列直接依赖于CustomerID主键,而不是相互依赖。

MySQL 数据库设计时通常会尽量满足第三范式,以确保数据的完整性和一致性,并减少数据冗余。然而,在实际应用中,有时候也会根据特定情况牺牲一些范式,以满足性能或其他需求。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值