SQL数据规范1NF、2NF、3NF
数据规范大致分为 第一范式 、第二范式、第三范式三类,今天我们就来详细探讨一下
第一范式:(1NF)无重复的列
首先第一范式,官方的定义是指数据库表的每一列都是不可分割的基本数据项,同一列中不能有多个值,即实体中的某个属性不能有多个值或者不能有重复的属性。如果出现重复的属性,就可能需要定义一个新的实体,新的实体由重复的属性构成,新实体与原实体之间为一对多关系。在第一范式1NF中表的每一行只包含一个实例的信息。简而言之,第一范式就是无重复的列,语言比较多,但实际上总结出来,就是一点,数据不重复且不可分割
以一个学生类进行示例:
假如我们需要统计学生的个人信息,常规的数据表设计方案是这样的
这样的一个表,结构上倒也能使用,但是如果后续的需求变为,让你统计学生中来自湖北的学生有多少,那这个数据结构就显得心有余而力不足了,这个时候我们应该将表优化为如下格式
这样子的话,省份|地市|区县|街道都可以参与条件查询与计算了,这个时候就满足第一范式了。
这个时候我们来从函数依赖的角度来研究这几个字段,这个表的候选码是学号和姓名,学号可以推导出姓名,姓名可以推导出性别和年龄,这个时候可以看出该表存在传递函数依赖,必然不满足第三范式,而学号、姓名无法推导出省份,地市等,说明这个表目前存在部分函数依赖,不满足第二范式,接下来我们来看看第二范式的定义。
第二范式:(2NF)属性完全依赖于主键
第二范式建立在第一范式的基础上,即满足第二范式一定满足第一范式,第二范式要求数据表每一个实例或者行必须被唯一标识。除满足第一范式外还有两个条件,一是表必须有一个主键;二是没有包含在主键中的列必须完全依赖于主键,而不能只依赖于主键的一部分。每一行的数据只能与其中一列相关,即一行数据只做一件事。只要数据列中出现数据重复,就要把表拆分开来。
那如果需要将上面的表修改为第二范式,需要进行下述拆分,就可以满足第二范式了;
表一:学号|姓名|性别|年龄|
表二:地址编号|省份|地市|区县|详细地址
第三范式:(3NF)属性不依赖于其它非主属性
第三范式若某一范式是第二范式,且每一个非主属性都不传递依赖于该范式的候选键,则称为第三范式,即不能存在:非主键列 A 依赖于非主键列 B,非主键列 B 依赖于主键的情况。
SQL数据规范1NF、2NF、3NF相关推荐
- 数据库范式解析(1NF 2NF 3NF BCNF)
数据库设计范式是关系型数据库的设计准则.其目的在于通过规划设计使得数据库结构合理,尽量减少数据冗余,消除存储异常,方便数据的插入.更新和删除操作.目前常用范式包括1NF(第一范式).2NF(第二范式) ...
- 数据库三大范式(1NF,2NF,3NF)及ER图
数据库三大范式(1NF,2NF,3NF)及ER图 百度官方解释: 设计关系数据库时,遵从不同的规范要求,设计出合理的关系型数据库,这些不同的规范要求被称为不同的范式,各种范式呈递次规范,越高的范式数据 ...
- 【数据库】范式理解:1NF,2NF,3NF,BCNF,4NF详析
数据库入门(一)范式理解:1NF,2NF,3NF,BCNF,4NF详析 引言 范式种类 第一范式(1NF) 符合1NF的关系中的每个属性都不可再分 存在问题 第二范式(2NF) 在1NF基础上消除了非 ...
- 3nf mysql表_数据库三大范式(1NF,2NF,3NF)及ER图
数据库三大范式(1NF,2NF,3NF)及ER图 百度官方解释: 设计关系数据库时,遵从不同的规范要求,设计出合理的关系型数据库,这些不同的规范要求被称为不同的范式,各种范式呈递次规范,越高的范式数据 ...
- 数据库1NF 2NF 3NF范式解释
数据库1NF 2NF 3NF范式解释 定义 范式(NF)"是什么意思.按照教材中的定义,范式是"符合某一种级别的关系模式的集合,表示一个关系内部各属性之间的联系的合理化程度&quo ...
- 1NF | 2NF | 3NF的区分以及什么是函数依赖、部分函数依赖、值传递依赖(最详细的讲解1NF、2NF、3NF的关系)
1NF | 2NF | 3NF的区分以及什么是函数依赖.部分函数依赖.值传递依赖 符合3NF一定符合2NF.一定符合1IF 简单区分.2NF不存在部分函数依赖,3NF不存在传递函数依赖 第一范式1NF ...
- 数据库随笔-1NF,2NF,3NF详解
数据库随笔-1NF,2NF,3NF详解 基础概念 通过表的更新来举例说明 总结 基础概念 1. 第一范式(1NF):每一列都是不可分割的原子数据项 2. 第二范式(2NF):在1NF的基础上,非码属性 ...
- 数据库范式1NF 2NF 3NF详细阐述
范式:关系数据库中的关系是要满足一定要求的,满足不同程度要求的不同范式.满足最低要求的叫第一范式,简称1NF ,在第一范式中满足进一步要求的为第二范式,其余以此类推.通俗来说是满足数据库关系表中的一套 ...
- 【转】关系型数据库的设计范式 1NF 2NF 3NF BCNF
本文转载自:https://www.cnblogs.com/langdashu/p/5924082.html 一.缘由: 要做好DBA,就要更好地理解数据库设计范式.数据库范式总结概览: 为了更好地理 ...
最新文章
- 【Spring框架家族】SpringBoot基本介绍
- 如何让PHP运行更高效
- 如何使用Prometheus采集SAP ABAP Netweaver的应用日志数据
- IBM在欧洲启动“智能云”研发计划
- C++默认构造函数的合成
- FEA-Net论文梳理
- Mysql Cluster集群实现高可用
- python sorted下标_Python列表实用的代码片段
- 2015年ps计算机试题,2015年计算机一级考试《PS》模拟试题及答案(一)(2)
- hdu1814 暴力
- 初学larval 第一篇(大神绕道哦,针对新手友好的一篇)
- 如何配置java环境_vscode配置java环境
- Nebula Graph学习篇1_基础概念、初步使用、整合SpringBoot使用
- 安卓一键清理内存_微清理下载软件-微清理app下载v1.0.1.2 安卓版
- 使用tensorflow进行简单的强化学习 1—Q-learning
- FreeRTOS软件定时器 基于STM32
- Java【冒泡排序】算法, 大白话式图文解析(附代码)
- 发顶会论文,怎么就那么难?
- FIP: A fast overlapping community-based influence maximization algorithm using probability coefficie
- 语法解析及Antlr
热门文章
- C++核心准则R.2: 只在接口中表示单独对象使用原始指针​
- java PEB算法加密
- 网页退出弹出新网页或者收藏夹
- Android 虚拟机:你需要掌握的基本知识
- AD域批量绑定邮箱地址
- android系统可行性分析,基于Android系统的移动学习平台研究与实现
- php洋葱模型,PHP Migrations——Doctrine Migrations教程
- oss上传报错_oss上传400报错-问答-阿里云开发者社区-阿里云
- 麦克风阵列语音增强beamforming算法
- 基于FPGA的VGA时序分析