MySQL:数据库表格设计三范式

数据库表格设计范式(三范式 1NF,2NF,3NF)
1NF:字段不可分;
2NF:有主键,非主键字段依赖主键;
3NF:非主键字段不能相互依赖;
解释:
1NF:原子性 字段不可再分,否则就不是关系数据库;
2NF:唯一性 一个表只说明一个事物;
3NF:每列都与主键有直接关系,不存在传递依赖;

第一范式(1NF)
即表的列的具有原子性,不可再分解,即列的信息,不能分解。通俗理解即一个字段只存储一项信息。
在这里插入图片描述

第二范式(2NF)
第二范式(2NF)是在第一范式(1NF)的基础上建立起来的,即满足第二范式(2NF)必须先满足第一范式(1NF)。第二范式要求每个表只描述一件事。
在这里插入图片描述
而实际上,产品编号与订单编号并没有明确的关系,订购日期与订单编号有关系,因为一旦订单编号确定下来了,订购日期也确定了,价格与订单编号也没有直接关系,而与产品有关,所以上面的表实际上可以拆分:
订单表:
在这里插入图片描述
产品表:
在这里插入图片描述
第三范式(3NF)
要求一个数据库表中不包含已在其它表中已包含的非主关键字信息。
例如,
存在一个部门信息表,其中每个部门有
部门编号(dept_id)、
部门名称、
部门简介等信息。
那么在员工信息表中列出部门编号后就不能再将部门名称、部门简介等与部门有关的信息再加入员工信息表中。

猜你喜欢

转载自blog.csdn.net/aixiangnan/article/details/89284212