`
寂地流年
  • 浏览: 27407 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

数据库设计范式

阅读更多

范式的原理

  • 第一范式(1NF)无重复的列

    所谓第一范式(1NF)是指数据库表的每一列都是不可分割的基本数据项,同一列中不能有多个值,即实体中的某个属性不能有多个值或者不能有重复的属性。如果出现重复的属性,就可能需要定义一个新的实体,新的实体由重复的属性构成,新实体与原实体之间为一对多关系。在第一范式(1NF)中表的每一行只包含一个实例的信息。简而言之,第一范式就是无重复的列。

    说明:在任何一个关系数据库中,第一范式(1NF)是对关系模式的基本要求,不满足第一范式(1NF)的数据库就不是关系数据库。

  • 第二范式(2NF)属性完全依赖于主键[消除部分子函数依赖]

    第二范式(2NF)是在第一范式(1NF)的基础上建立起来的,即满足第二范式(2NF)必须先满足第一范式(1NF)。第二范式(2NF)要求数据库表中的每个实例或行必须可以被惟一地区分。为实现区分通常需要为表加上一个列,以存储各个实例的惟一标识。

    例如员工信息表中加上了员工编号(emp_id)列,因为每个员工的员工编号是惟一的,因此每个员工可以被惟一区分。这个惟一属性列被称为主关键字或主键、主码。

    第二范式(2NF)要求实体的属性完全依赖于主关键字。所谓完全依赖是指不能存在仅依赖主关键字一部分的属性,如果存在,那么这个属性和主关键字的这一部分应该分离出来形成一个新的实体,新实体与原实体之间是一对多的关系。为实现区分通常需要为表加上一个列,以存储各个实例的惟一标识。简而言之,第二范式就是属性完全依赖于主键。

  • 第三范式(3NF)属性不依赖于其它非主属性[消除传递依赖]

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

    那么在的员工信息表中列出部门编号后就不能再将部门名称、部门简介等与部门有关的信息再加入员工信息表中。如果不存在部门信息表,则根据第三范式(3NF)也应该构建它,否则就会有大量的数据冗余。简而言之,第三范式就是属性不依赖于其它非主属性。

范式的说明

  • 第一范式:1NF是对属性的原子性约束,要求属性具有原子性,不可再分解;

    通俗的理解是字段还可以再分吗?如过不能,则是符合1NF的设计。

  • 第二范式:2NF是对记录的惟一性约束,要求记录有惟一标识,即实体的惟一性;

    简单的解释,比如你和一个女生约会建立一张表,不用每条约会记录都记录她的身高、体重,将身高体重单独的存在一张表中供查询即可。

  • 第三范式:3NF是对字段冗余性的约束,即任何字段不能由其他字段派生出来,它要求字段没有冗余。
    打个比方,比如评论表,如果你将用户ID,用户头像都放在这留言表中,就是不合适的了。用户头像是依赖于用户ID,而不依赖该评论。

我对范式的理解
一个严格恪守数据库设计范式来进行数据库设计的人,必定是个傻球;
一个没有研究过数据库设计范式就进行数据库设计的人,必定也是个傻球;

在现代数据库设计中,尤其是web 2.0的系统中的数据库设计,我可以断言,大多数都是违反2NF、3NF的,少数设计甚至是违反1NF的。数据库设计范式只是对数据库惯用设计的一些说明,并不能定性为标准。

而从数据库的发展来看,以MySQL举例,随着MySQL实现越来越多的功能,它的宣传材料上会越来越多的出现以前被MySQL所摒弃的复杂设计理念,并且宣称这是MySQL所独创或一贯倡导的。这是一个数据库系统发展所必然经历的过程。而这却会给MySQL的使用者以极大的误导,从而忽视了是否新特性是业务所真正需要的。

数据库设计不是一种编程语言这么简单,与面向对象、面向过程无关。数据库设计代表的是一种与应用开发语言完全不同的思想。现在绝大多数的程序,无论任何人采用什么方式进行程序开发,其最终还是会回归到对数据库的操作上(当然如果你的程序只是个教学演示则不在此范围内)。

分享到:
评论

相关推荐

    数据库设计范式最好的讲解

    "数据库设计范式的重要性" database设计范式是关系数据库的基础规范,关系数据库的设计必须遵循这些规范,否则将会导致数据库设计混乱、数据冗余、查询效率低下等问题。本文将详细介绍数据库设计范式的概念、类型和...

    Oracle 数据库设计范式 PowerDesigner

    Oracle数据库设计范式是数据库设计中的核心概念,它关乎数据的组织方式,旨在减少数据冗余,提高数据的一致性和可维护性。PowerDesigner则是一款强大的数据库建模工具,可以帮助我们实现这些设计范式,从而优化...

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

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

    关系数据库设计范式培训

    关系数据库设计范式是数据库设计中的核心概念,用于确保数据的规范化和高效存储。以下是关于关系数据库设计范式的详细介绍: 1. 第一范式(1NF):这是最基本的要求,规定数据库表中的每一列(属性)都必须是不可再...

    关系型数据库设计范式

    关系型数据库设计范式是数据库设计的核心原则,用于确保数据的一致性、减少冗余和避免数据异常。在设计数据库时,遵循这些范式能够提高数据的组织效率和查询性能,降低维护成本。以下是四种主要的范式以及它们的解释...

    数据库设计范式简单入门

    ### 数据库设计范式详解 #### 一、引言 在关系数据库的设计过程中,遵循一定的设计规范至关重要。这些规范能够确保数据库的结构合理、数据冗余最小化,并且避免数据异常的发生。其中最重要的规范之一便是“数据库...

    MLDN魔乐科技JAVA培训_Oracle课堂25_数据库设计范式 PowerDesigner工具.rar

    本资源"MLDN魔乐科技JAVA培训_Oracle课堂25_数据库设计范式 PowerDesigner工具.rar"聚焦于数据库设计的重要概念——范式,以及使用PowerDesigner工具进行设计的实践。 数据库设计范式是数据库理论中的核心概念,它...

    Oracle学习笔记(数据库设计范式 PowerDesigner工具)

    Oracle学习笔记(数据库设计范式 PowerDesigner工具),有具体的代码案例

    数据库设计范式.doc

    数据库设计范式是数据库设计的重要理论基础,用于指导创建高效、稳定的数据库结构。数据库设计的三大范式——第一范式(1NF)、第二范式(2NF)和第三范式(3NF)——旨在减少数据冗余、避免更新异常、插入异常和...

    关系数据库设计范式.ppt

    关系数据库设计范式是数据库设计的重要理论基础,它规范了数据库的设计过程,以确保数据的一致性、完整性和减少冗余。在关系数据库中,数据以表格形式存储,这些表格遵循特定的规则,以满足不同级别的范式要求。 ...

    MLDN魔乐科技_Oracle课堂25_数据库设计范式.PowerDesigner工具

    本资源“MLDN魔乐科技_Oracle课堂25_数据库设计范式.PowerDesigner工具”聚焦于数据库设计中的范式理论以及PowerDesigner这一强大的数据库建模工具。 首先,数据库设计范式是数据库理论中的核心概念,它有助于避免...

    数据库设计范式(实例).doc

    数据库设计范式是关系数据库设计的核心原则,它们确保了数据的一致性、减少冗余和避免数据异常。这里主要介绍了1NF(第一范式)、2NF(第二范式)、3NF(第三范式)和BCNF(博科斯范式)。 1NF(第一范式)强调每个...

    数据库设计范式针对(专业的数据模型设计)

    数据库设计范式是关系数据库设计的核心概念,它们确保了数据的规范化程度,从而避免数据冗余和不一致性。关系数据库的范式分为六个级别:第一范式(1NF)、第二范式(2NF)、第三范式(3NF)、第四范式(4NF)、第五...

    [学习笔记]数据库设计范式

    数据库设计范式学习笔记,1NF/2NF/3NF/BCNF/4NF

    数据库三大范式详解

    设计范式(范式,数据库设计范式,数据库的设计范式)是符合某一种级别的关系模式的集合。构造数据库必须遵循一定的规则。在关系数据库中,这种规则就是范式。关系数据库中的关系必须满足一定的要求,即满足不同的...

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

    常见的数据库设计范式包括第一范式(1NF)、第二范式(2NF)、第三范式(3NF)等。以下是对这些范式的详细介绍和实例分析。 一、第一范式(1NF) 第一范式(1NF)是数据库设计的基本要求,指数据库表的每一列都是...

    “做中学”在计算机理论教学中的应用——以Oracle数据库设计范式教学为例.pdf

    “做中学”在计算机理论教学中的应用——以Oracle数据库设计范式教学为例.pdf

Global site tag (gtag.js) - Google Analytics