`

第一范式,第二范式,第三范式

阅读更多

转载自:http://blog.csdn.net/famousdt/article/details/6921622

 

范式:英文名称是 Normal Form,它是英国人 E.F.Codd(关系数据库的老祖宗)在上个世纪70年代提出关系数据库模型后总结出来的,范式是关系数据库理论的基础,也是我们在设计数据库结构过程中所要遵循的规则和指导方法。目前有迹可寻的共有8种范式,依次是:1NF,2NF,3NF,BCNF,4NF,5NF,DKNF,6NF。通常所用到的只是前三个范式,即:第一范式(1NF),第二范式(2NF),第三范式(3NF)。下面就简单介绍下这三个范式。

 

◆ 第一范式(1NF):强调的是列的原子性,即列不能够再分成其他几列。
考虑这样一个表:【联系人】(姓名,性别,电话)

如果在实际场景中,一个联系人有家庭电话和公司电话,那么这种表结构设计就没有达到 1NF。要符合 1NF 我们只需把列(电话)拆分,即:【联系人】(姓名,性别,家庭电话,公司电话)。1NF 很好辨别,但是 2NF 和 3NF 就容易搞混淆。

 

◆ 第二范式(2NF):首先是 1NF,另外包含两部分内容,一是表必须有一个主键;二是没有包含在主键中的列必须完全依赖于主键,而不能只依赖于主键的一部分。
考虑一个订单明细表:【OrderDetail】(OrderID,ProductID,UnitPrice,Discount,Quantity,ProductName)。
因为我们知道在一个订单中可以订购多种产品,所以单单一个 OrderID 是不足以成为主键的,主键应该是(OrderID,ProductID)。显而易见 Discount(折扣),Quantity(数量)完全依赖(取决)于主键(OderID,ProductID),而 UnitPrice,ProductName 只依赖于 ProductID。所以 OrderDetail 表不符合 2NF。不符合 2NF 的设计容易产生冗余数据。

可以把【OrderDetail】表拆分为【OrderDetail】(OrderID,ProductID,Discount,Quantity)和【Product】(ProductID,UnitPrice,ProductName)来消除原订单表中UnitPrice,ProductName多次重复的情况。

 

◆ 第三范式(3NF):首先是 2NF,另外非主键列必须直接依赖于主键,不能存在传递依赖。即不能存在:非主键列 A 依赖于非主键列 B,非主键列 B 依赖于主键的情况。
考虑一个订单表【Order】(OrderID,OrderDate,CustomerID,CustomerName,CustomerAddr,CustomerCity)主键是(OrderID)。
其中 OrderDate,CustomerID,CustomerName,CustomerAddr,CustomerCity 等非主键列都完全依赖于主键(OrderID),所以符合 2NF。不过问题是 CustomerName,CustomerAddr,CustomerCity 直接依赖的是 CustomerID(非主键列),而不是直接依赖于主键,它是通过传递才依赖于主键,所以不符合 3NF。

通过拆分【Order】为【Order】(OrderID,OrderDate,CustomerID)和【Customer】(CustomerID,CustomerName,CustomerAddr,CustomerCity)从而达到 3NF。

 

第二范式(2NF)和第三范式(3NF)的概念很容易混淆,区分它们的关键点在于,2NF:非主键列是否完全依赖于主键,还是依赖于主键的一部分3NF:非主键列是直接依赖于主键,还是直接依赖于非主键列

分享到:
评论

相关推荐

    数据库设计的第一范式第二范式第三范式描述和实例

    数据库设计的第一范式第二范式第三范式描述和实例 数据库设计的范式是指数据库设计时需要遵循的一些基本规则,以确保数据库的结构清晰、简洁、高效。常见的数据库设计范式包括第一范式(1NF)、第二范式(2NF)、第...

    数据库三大范式详解

    目前关系数据库有六种范式:第一范式(1NF)、第二范式(2NF)、第三范式(3NF)、第四范式(4NF)、第五范式(5NF)和第六范式(6NF)。满足最低要求的范式是第一范式(1NF)。在第一范式的基础上进一步满足更多...

    数据库三范式

    第三范式是在第二范式的基础上,确保所有的非主键列不仅直接依赖于主键,而且不依赖于其他非主键列。换句话说,表中的每列都应该直接依赖于主键,或者不依赖于任何其他列。这有助于消除不必要的冗余数据,并提高数据...

    数据库设计三大范式应用实例剖析

    数据库的设计范式是数据库设计所需要满足的规范,满足这些规范的数据库是简洁的、结构明晰的,同时,...第三范式:在第二范式的基础上,数据表中如果不存在非关键字段对任一候选关键字段的传递函数依赖则符合第三范式。

    SqlServer 第三范式

    第一范式是指关系模式中的每一个元组都是不可分割的整体,第二范式是指关系模式中的每一个非主键属性都完全函数依赖于候选键,第三范式是指关系模式中的每一个非主键属性都不传递函数依赖于候选键。 通过了解关系...

    数据库设计范式数据库设计范式

    目前关系数据库有六种范式:第一范式(1NF)、第二范式(2NF)、第三范式(3NF)、第四范式(4NF)、第五范式(5NF)和第六范式(6NF)。满足最低要求的范式是第一范式(1NF)。在第一范式的基础上进一步满足更多...

    MySQL三大范式详解.docx

    MySQL 三大范式是关系型数据库设计的基础,它们分别是第一范式(1NF)、第二范式(2NF)和第三范式(3NF)。下面我们将详细介绍 MySQL 三大范式的定义、特点和应用。 第一范式(1NF) 第一范式(1NF)是指数据库表...

    SQL 第三范式 规范化设计数据库范例 数据库设计示例

    SQL 第三范式 规范化...本资源摘要信息提供了一个非常实用的数据库设计示例,讲述了 SQL 第三范式在数据库设计中的应用和实现,并且介绍了数据表设计的重要性、数据规范化、函数依赖、第二范式和第三范式等重要概念。

    数据库范式【转】

    数据库范式通常有三种:第一范式、第二范式和第三范式。下面将对每种范式进行详细的介绍。 第一范式 第一范式是最基本的范式,它要求关系模式 R 中所有属性的值域都是单纯域。也就是说,每个列都只能包含单个值,不...

    数据库设计第三范式详解

    第三范式是在满足2NF的基础上,进一步确保非主属性不依赖于候选键的任何部分,而是依赖于整个候选键。 举个例子,假设我们有一个“学生选课”表,包含以下字段:学生ID(主键),课程ID,教师ID,学分。在这个设计...

    三种主要范式的介绍及一些基本概念的描述

    本文将详细介绍关系数据库中的三种主要范式:第一范式(1NF)、第二范式(2NF)以及第三范式(3NF),这三种范式是数据库设计中最常提及的概念。 ### 第一范式(1NF) 第一范式是数据库规范化的基础,也是所有其他...

    数据库设计三范式

    尤其是数据库设计范式 现简单介绍1NF(第一范式),2NF(第二范式),3NF(第三范式)和BCNF,另有第四范式和第五范式留到以后再介绍。 在你设计数据库之时,若能符合这几个范式,你就是数据库设计的高手

    数据库范式理解例题数据库范式理解例题.doc

    其中包括第一范式(1NF)、第二范式(2NF)和第三范式(3NF)等。 第一范式(1NF) 第一范式是最基本的数据库设计规范,它要求每个表中的每一行都具有唯一的值,且每个字段都不可分割。换言之,每个表中的每一行都...

    sql三个范式举例.doc

    SQL三个范式是数据库设计中重要的理论基础,它们分别是第一范式(1NF)、第二范式(2NF)和第三范式(3NF)。这些范式确保了数据库的规范化,避免数据冗余和操作异常,从而提高数据的完整性和一致性。 1. **第一...

    Java面试中数据库三范式详解

    第三范式的定义是:在 2NF 的基础上,每个非主属性都不传递依赖于 R 的候选键(码)。也就是说,在一个数据库表中,每个非关键字段都不传递依赖于候选关键字。如果存在非关键字段对候选关键字的传递函数依赖,那么这...

    05-数据库设计三范式1

    这里我们将深入探讨第一范式(1NF)和第二范式(2NF)。 **第一范式(1NF)** 第一范式强调的是列的原子性,即每个表的列都应包含不可再分的最小数据单元。在关系数据库中,1NF 是最基本的要求,它要求数据库表的每...

    三大范式应用与理解

    主要的范式有三个,即第一范式(1NF)、第二范式(2NF)和第三范式(3NF),还有更高层次的鲍依斯-科得范式(BCNF)。这些范式的目标是减少数据冗余,避免数据更新时出现异常,如插入异常、删除异常和更新异常。 第...

    数据库的三个范式

    三个范式是数据库规范化的基本概念,它们分别是第一范式(1NF)、第二范式(2NF)和第三范式(3NF)。 第一范式(1NF) 第一范式是对属性的原子性约束,要求属性具有原子性,不可再分解。换言之,每个记录中的每个...

    db设计之第三范式讲解

    以下是第一范式、第二范式和第三范式的详细解释: **第一范式(1NF)**: 1NF 是最基本的要求,它规定数据库表的每一列都应是不可分割的基本数据项。这意味着每个字段只存储单一值,不允许有复合字段。例如,在员工...

    软考系分之数据库第一二三范式及BCNF范式

    本文将详细介绍第一、第二、第三范式以及BCNF范式,并结合具体示例来帮助理解这些概念。 ### 一、第一范式(1NF) #### 定义: 第一范式要求关系模式中的每一个列都具有原子性,即列的值不能再被细分。简单来说,...

Global site tag (gtag.js) - Google Analytics