转载自http://www.cnblogs.com/linjiqin/archive/2012/04/01/2428695.html
在实际开发中最为常见的设计范式有三个:
1.第一范式(确保每列保持原子性)
第一范式是最基本的范式。如果数据库表中的所有字段值都是不可分解的原子值,就说明该数据库表满足了第一范式。
第一范式的合理遵循需要根据系统的实际需求来定。比如某些数据库系统中需要用到“地址”这个属性,本来直接将“地址”属性设计成一个数据库表的字段就行。但是如果系统经常会访问“地址”属性中的“城市”部分,那么就非要将“地址”这个属性重新拆分为省份、城市、详细地址等多个部分进行存储,这样在对地址中某一部分操作的时候将非常方便。这样设计才算满足了数据库的第一范式。
2.第二范式(确保表中的每列都和主键相关)
第二范式在第一范式的基础之上更进一层。第二范式需要确保数据库表中的每一列都和主键相关,而不能只与主键的某一部分相关(主要针对联合主键而言)。也就是说在一个数据库表中,一个表中只能保存一种数据,不可以把多种数据保存在同一张数据库表中。
3.第三范式(确保每列都和主键列直接相关,而不是间接相关)
第三范式需要确保数据表中的每一列数据都和主键直接相关,而不能间接相关。
三大范式作用:1、解决数据冗余
2、数据有效性检查
3、提高存储效率。
注意:
规范化也有缺点:由于将一个表拆分成为多个表,在查询时需要多表连接,降低了查询速度。有时候为了查询性能上的考虑,也会违反三大范式的。
分享到:
相关推荐
数据库三大范式详解 数据库范式1NF 2NF 3NF BCNF(实例) 设计范式(范式,数据库设计范式,数据库的设计范式)是符合某一种级别的关系模式的集合。构造数据库必须遵循一定的规则。在关系数据库中,这种规则就是范式...
此文档是关于数据库三大范式的描述,以及在何种情况下应该用何种范式已达到数据库的良好效率!
数据库的设计范式是数据库设计所需要满足的规范,满足这些规范的数据库是简洁的、结构明晰的,同时,...第三范式:在第二范式的基础上,数据表中如果不存在非关键字段对任一候选关键字段的传递函数依赖则符合第三范式。
大数据开发培训数据库三大范式浅析.doc
关系数据库三个范式理解实例,举例,20个字补丁
### 数据库设计三大范式应用实例剖析 #### 引言 数据库的设计范式是指一系列用于指导数据库设计的规范化准则,其目的是确保数据的完整性、减少数据冗余,并提高数据库的操作效率。遵循这些范式可以避免在数据库...
数据库的设计的学习,一些基本的介绍,简单明了,还是很容易理解。
在数据库设计中,三大范式是确保数据结构合理化和避免冗余的关键原则。以下是它们的详细解释: **第一范式(1NF)**: 1NF要求数据库表中的每个字段都是单一属性,不可再分。这意味着每个字段只能包含基本数据类型...
在数据库设计中,三大范式是确保数据结构规范化和避免数据冗余的关键原则。这些范式对于优化数据库性能,减少数据更新异常和提高数据一致性至关重要。以下是对Sql Server数据库三大范式的详细介绍: **第一范式(1...
### 数据库三范式详解 在数据库设计领域中,遵循一系列规范来构建高效、合理的关系型数据库至关重要。这些规范称为“范式”,旨在减少数据冗余并提高数据完整性。范式按照递进的方式进行规范,越高级别的范式对...
数据库范式是数据库设计的基本准则,它是一种规范化理论,用于减少数据冗余和提高数据的一致性。在数据库设计中,通常遵循三个主要的范式:第一范式(1NF)、第二范式(2NF)和第三范式(3NF),以及更高级的BC范式...
尤其是数据库设计范式 现简单介绍1NF(第一范式),2NF(第二范式),3NF(第三范式)和BCNF,另有第四范式和第五范式留到以后再介绍。 在你设计数据库之时,若能符合这几个范式,你就是数据库设计的高手
数据库的三范式是什么? 第一范式:最基本要求,表中的每一列必须保证原子性,列不可在分割。 如有一个列,年级班级。然后存储数据为,一年级一班,一年级二班。那么这是错误的,应该年级和班级分开为单独列。 ...
数据库范式理解例题 数据库范式是relation database设计中的一种规范,旨在确保数据库的结构正确性和数据的一致性。其中包括第一范式(1NF)、第二范式(2NF)和第三范式(3NF)等。 第一范式(1NF) 第一范式是...
数据库设计三范式是数据库规范化理论中的核心概念,主要用于优化数据存储,避免数据冗余和更新异常。这里我们将深入探讨第一范式(1NF)和第二范式(2NF)。 **第一范式(1NF)** 第一范式强调的是列的原子性,即每...
数据库设计是构建高效、稳定的信息系统的关键步骤,其中三大范式——第一范式(1NF)、第二范式(2NF)和第三范式(3NF)是关系型数据库设计的基本准则,它们旨在减少数据冗余,提高数据一致性,并降低更新异常的...