一、三范式定义:
什么是范式:简言之就是,数据库设计对数据的存储性能,还有开发人员对数据的操作都有莫大的关系。所以建立科学的,规范的的数据库是需要满足一些规范的来优化数据数据存储方式。在关系型数据库中这些规范就可以称为范式。
第一范式(1NF):原子性 ,字段不可再分,否则就不是关系数据库;
第二范式(2NF):唯一性 , 有主键,非主键字段依赖主键;
第三范式(3NF):非主键字段不能相互依赖,比如,每列都与主键有直接关系,不存在传递依赖;
二、三范式的解释
第一范式(1NF)
第一范式(1NF)即表的列的具有原子性,不可再分解,即列的信息,不能分解。通俗理解即一个字段只存储一项信息,一个表只说明一个事物。
两列的属性相近或相似或一样,尽量合并属性一样的列,确保不产生冗余数据。
第二范式(2NF)
第二范式(2NF)是在第一范式(1NF)的基础上建立起来的,即满足第二范式(2NF)必须先满足第一范式(1NF)。第二范式要求每个表只描述一件事。
而实际上,产品编号与订单编号并没有明确的关系,订购日期与订单编号有关系,因为一旦订单编号确定下来了,订购日期也确定了,价格与订单编号也没有直接关系,而与产品有关,所以上面的表实际上可以拆分:
订单表:
产品表:
第三范式(3NF)
第三范式(3NF) 要求一个数据库表中不包含已在其它表中已包含的非主关键字信息。
例如,
存在一个部门信息表,其中每个部门有 部门编号(dept_id)、部门名称、部门简介等信息。
那么在员工信息表中列出部门编号后就不能再将部门名称、部门简介等与部门有关的信息再加入员工信息表中。