上篇主要是说了些基本表的一些基本概念,这一篇主要是想说一下范式的应用。
在大二的时候学数据库的时候是学的SQL Server数据库,里面也讲到了范式,现在就来看看三大范式。
第一范式:如果每列(或者每个属性)都是不可再分的最小数据单元(也称为最小的原子单元),则满足第一范式.比如一个工人的基本信息表,里面有工人的工号,性别,年龄,这些属性都是不可分割的,所以这个表就符合了第一范式。
第二范式: 就是在第一范式的基础上延伸,使之表里的每个字段都与主键发生关系。假如一个关系满足第一范式,并且除了主键以外的其它字段,都依赖于该主键,则满足第二范式.
例如:订单表(订单编号、产品编号、定购日期、价格、……),"订单编号"为主键,"产品编号"和主键列没有直接的关系,即"产品编号"列不依赖于主键列,这个列我们就可以把它删除。
第三范式:在第二范式的基础上更进一步,也就是为了实现表里的列都与主键列直接相关,不是间接相关。这个我们可以用“Armstrong 公理”中的传递规则来推理。
我们来看一下它的定义:
设U是关系模式R 的属性集,F 是R 上成立的只涉及U 中属性的函数依赖集。若X→Y 和 Y→Z在R 上成立,则X →Z 在R 上成立。因此我们就来看在网上搜索到的例子:例如:订单表(订单编号,定购日期,顾客编号,顾客姓名,……),初看该表没有问题,满足第二范式,每列都和主键列"订单编号"相关,再细看你会发现"顾客姓名"和"顾客编号"相关,"顾客编号"和"订单编号"又相关,最后经过传递依赖,"顾客姓名"也和"订单编号"相关。为了满足第三范式,应去掉"顾客姓名"列,放入客户表中。
这里其实就是为了说明数据库的表里步要出现冗余,在顾客表里已经有了"顾客姓名"了,而在订单表里就别出现了,而直接根据顾客编号相关联就可以,否则造成资源浪费。
以上就是三大范式。
延伸:我们来看这三大范式:
第一范式:1NF是对属性的原子性约束,要求属性具有原子性,不可再分解;
第二范式:2NF是对记录的惟一性约束,要求记录有惟一标识,即实体的惟一性;
第三范式:3NF是对字段冗余性的约束,即任何字段不能由其他字段派生出来,它要求字段没有冗余。
其实在设计数据库的时候我们最多的要遵循的就是第三范式,但是并不是越满足第三范式数据库就设计的越完美,这种错误是错误的。有时候增加点冗余相反的会提高访问速率,因此在实际的设计过程中应降低对范式的要求。
以前对数据冗余并不是很了解,在百度知道里的定义是这样的:在一个数据集合中重复的数据称为数据冗余. 但是不是说我们表的主键在其他表里重复出现就是冗余,这不是,而是为了连接两个表。只有非键字段就是既不是主键外键等约束的键如果重复出现,就会形成数据冗余。数据冗余也包括重复性冗余和派生冗余。比如工人表里有"基本工资","奖金"两列,然后还有一个"总工资"的列,这个总工资就是派生冗余。低级的重复性冗余一定要避免,杜绝,但是像派生冗余还是提倡的因为它能提高访问的效率。
分享到:
相关推荐
数据库索引设计原则 数据库索引设计原则是 Oracle 数据库管理系统中的一项重要技术,旨在提高数据库的查询效率和性能。以下是数据库索引设计原则的详细解释。 一、基本原则 数据库索引设计原则的基本原则是确保...
二、数据库表设计原则 数据库表设计需要遵循一定的原则和标准,以确保设计的数据库表结构合理、可靠、可扩展。常见的数据库表设计原则包括: 1. 第三范式(3NF):数据库表设计应该遵循第三范式,即每个表中的每一...
### 经典数据库设计14个原则 #### 1. 实体关系的一对一、一对多、多对多关系 - **定义与解释**:在数据库设计中,实体之间的关系通常分为一对一(1:1)、一对多(1:N)或多对多(N:M)。一对一指的是两个实体之间...
### 11个重要的数据库设计原则 #### 规则1:明确应用程序的性质(OLTP还是OLAP) 在设计数据库之前,首要任务是确定应用程序的主要功能类型:事务处理(OLTP,Online Transaction Processing)还是分析处理(OLAP...
2. **表设计**:在数据库设计中,表设计是核心环节,它定义了数据如何组织和存储。这涉及到以下几个方面: - 字段定义:每个表由多个字段组成,每个字段都有特定的数据类型(如整数、文本、日期等)和属性(如是否...
本文将探讨一些核心的设计原则,旨在优化数据库的设计,提高系统的整体性能。 首先,简洁明了的命名规范至关重要。数据库、表和字段的命名应当清晰反映其用途,如使用公司简称加系统名称来命名数据库,如"BxxCRM"。...
数据库设计原则 6 1.2.1. 数据库SID 6 1.2.2. 数据库全局名 6 1.2.3. 数据库类型选择 6 1.2.4. 数据库连接类型选择 7 1.2.5. 数据库SGA配置 7 1.2.6. 数据库字符集选择 8 1.2.7. 数据库其他参数配置 9 1.2.8. ...
数据库设计原则总结 本文总结了数据库设计的重要原则,包括原始单据与实体之间的关系、主键与外键的设计、基本表的性质、范式标准、通俗地理解三个范式、要善于识别与正确处理多对多的关系、主键PK的取值方法等七个...
"数据库中表的主键设计原则收藏" 在设计数据库表时,主键的设计是非常重要的一步。一个好的主键设计可以提高数据库的性能和可维护性,而一个糟糕的主键设计可能会带来一系列的问题。本文将讨论数据库中表的主键设计...
以下是关于“数据库设计原则14法则”的详细解析: 1. 原始单据与实体之间的关系:数据库设计时,需要考虑原始数据源(如业务表格)与实体表之间的映射。通常,一张原始单据对应一个实体,但也有特殊情况,如一对一...
### MySQL数据库设计原则详解 #### 一、引言 在当今数据驱动的世界中,数据库设计的质量直接影响着应用程序的性能和可扩展性。MySQL作为一款广泛使用的开源关系型数据库管理系统,其设计原则对于确保数据的一致性...
### 数据库设计原则与技巧详解 #### 一、数据库设计原则概述 数据库设计是构建高效、稳定、可扩展数据存储系统的关键步骤。优秀的数据库设计不仅能提高数据管理的效率,还能确保数据的一致性和完整性,降低后期...
以下将详细讨论在设计数据库表时的一些关键经验和原则。 首先,让我们关注使用GUID(全局唯一标识符)作为主键。主键是数据库表中识别每条记录的独一无二的标识,它的选择至关重要。GUID因其全球唯一性,成为了理想...
在关系数据库设计过程中,遵循设计范式(如第一范式、第二范式等)是非常重要的原则之一,目的是减少数据冗余并确保数据结构合理,避免存储异常。然而,在实际应用中,适当地使用冗余数据反而能够提高数据查询效率和...
以下是一些核心的数据库设计原则和技巧,特别针对Oracle数据库: 1. **第三范式(3NF)**:3NF是数据库设计中常见的规范化程度,旨在减少数据冗余和提高数据一致性。它要求表中的每个非主键字段都完全依赖于主键,...
### 关系数据库设计原则 1. **规范化**:通过对表结构的设计,消除数据冗余和异常,提高数据一致性和准确性。通常分为一范式、二范式、三范式乃至更高层次的规范化。 2. **反规范化**:在某些情况下为了提高查询...
【大型数据库的设计原则与开发技巧】 在当今信息化社会,数据库已成为支撑各类系统运行的核心部分,尤其是在大型系统中,数据库的设计质量直接影响着系统的性能和稳定性。本文将深入探讨大型数据库的设计原则与开发...
本文将深入探讨数据库表设计的关键知识点,包括数据规范化、关系模型、索引优化、表关联以及设计原则。 首先,数据规范化是数据库设计的基础。它旨在减少数据冗余,提高数据的一致性和完整性。第一范式(1NF)要求...
数据库表设计是构建高效、稳定、可扩展的数据库系统的核心环节。它涉及到多个关键知识点,包括...在实际应用中,如交友网站的设计,我们需要综合运用各种数据库设计原则和技术,以满足功能需求并提供良好的用户体验。