数据库设计三范式

一、三范式定义:

什么是范式:简言之就是,数据库设计对数据的存储性能,还有开发人员对数据的操作都有莫大的关系。所以建立科学的,规范的的数据库是需要满足一些规范的来优化数据数据存储方式。在关系型数据库中这些规范就可以称为范式。
第一范式(1NF):原子性 ,字段不可再分,否则就不是关系数据库;
第二范式(2NF):唯一性 , 有主键,非主键字段依赖主键;
第三范式(3NF):非主键字段不能相互依赖,比如,每列都与主键有直接关系,不存在传递依赖;

二、三范式的解释

第一范式(1NF)

第一范式(1NF)即表的列的具有原子性,不可再分解,即列的信息,不能分解。通俗理解即一个字段只存储一项信息,一个表只说明一个事物。
在这里插入图片描述
两列的属性相近或相似或一样,尽量合并属性一样的列,确保不产生冗余数据。

第二范式(2NF)

第二范式(2NF)是在第一范式(1NF)的基础上建立起来的,即满足第二范式(2NF)必须先满足第一范式(1NF)。第二范式要求每个表只描述一件事。
在这里插入图片描述
而实际上,产品编号与订单编号并没有明确的关系,订购日期与订单编号有关系,因为一旦订单编号确定下来了,订购日期也确定了,价格与订单编号也没有直接关系,而与产品有关,所以上面的表实际上可以拆分:
订单表:
在这里插入图片描述
产品表:
在这里插入图片描述

第三范式(3NF)
第三范式(3NF) 要求一个数据库表中不包含已在其它表中已包含的非主关键字信息。
例如,
存在一个部门信息表,其中每个部门有 部门编号(dept_id)、部门名称、部门简介等信息。

那么在员工信息表中列出部门编号后就不能再将部门名称、部门简介等与部门有关的信息再加入员工信息表中。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值