数据库的三大范式

这篇具有很好参考价值的文章主要介绍了数据库的三大范式。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。


文章是看尚硅谷的MySQL所写的笔记

1.为什么需要数据库设计

设计数据表的时候,要考虑很多的问题:

  • 用户需要哪些数据,我们在数据表中要保存哪一些数据
  • 怎么保证数据表中的数据的正确性
  • 如何降低数据表的冗余度
  • 开发人员怎么才能更方便的使用数据库

如果数据库设计得不合理的话,可能导致下面的几种问题:

  • 设计容易,信息重复,存储空间浪费
  • 数据更新,插入,删除的异常
  • 不能正确表示信息
  • 丢失有效信息
  • 程序性能差

我们可以看出设计良好的数据库是很重要的,它有下面的优点:

  • 节省数据的存储空间
  • 能够保证数据的完整性
  • 方便进行数据库应用系统的开发

设计数据库,我们得重视数据表的设计,为了建立冗余度小,结构合理的数据库,设计数据库必须遵循一定的规则。

2.范式(Normal Formal)

2.1范式概述

关系型数据库中,关于数据表设计的基本原则,规则就称为范式,范式是我们在设计数据库结构过程中需要遵循的规则和指导方法。
三范式,MySQL,数据库,设计规范,mysql
不过,有的时候为了提高某一些查询性能,我们还需要破坏范式规则,也就是反规范化。

2.2键和相关属性的概念

范式的定义会用到主键和候选键,我们先来看看相关的概念,数据库中的键是由一个或多个属性组成的,我们来看一下数据表中常用的几种键和属性的定义。
三范式,MySQL,数据库,设计规范,mysql

三范式,MySQL,数据库,设计规范,mysql

2.3第一范式(1NF)

  • 第一范式主要是保证数据表中的每一个字段的值必须具有原子性,也就是数据表中的每个字段的值是不可再拆分的最小数据单元
  • 三范式,MySQL,数据库,设计规范,mysql
  • 三范式,MySQL,数据库,设计规范,mysql
  • 属性的原子性是主观的,我们要根据实际项目的需求来设计,比如说地址,如果项目没有说要细分为省,市,县,镇这么具体的话,我们一般就可以不拆分。

2.4第二范式(2NF)

  • 第二范式要求在满足第一范式的基础上,还要满足数据表里的每一条数据记录,都是可唯一标识的,而且所有的非主键字段,都必须完全依赖主键,不能只依赖主键的一部分。
  • 如果知道主键的所有属性的值,我们就可以检索任何元组(行)的任何属性的任何值(要求中的主键可以拓展替换为候选键)
  • 三范式,MySQL,数据库,设计规范,mysql

比如说,在成绩表(学号,课程号,成绩)关系中,(学号,课程号)可以决定成绩,因为一个学生可以选多门课,一门课也可以被多个学生选择,所以学号或课程号都不能单独决定成绩。
所以(学号,课程号)——>成绩就是完全依赖关系。

比赛表里面包含球员编号,姓名,年龄,比赛编号,比赛实际和比赛场地等属性,候选键和主键都是(球员编号,比赛编号),我们可以通过候选键(主键)来决定下面的关系。
(球员编号,比赛编号)——>(姓名,年龄,比赛时间,比赛场地,得分)
但是这个数据表不满足第二范式,因为数据表中的字段之间还存在下面的对应关系:

(球员编号)——>(姓名,年龄)
(比赛编号)——>(比赛时间,比赛场地)
非主属性并非完全依赖候选键,这样会产生下面的问题。

  • 数据冗余:如果一个球员参加m场比赛,那么球员的姓名和年龄就重复了m-1次,一个比赛可能有n个球员参加,比赛时间和地点就重复了n-1次
  • 插入异常:如果我们要添加一场新的比赛,但是这时还没有确定参加的球员都有谁2,那么就没发插入
  • 删除异常:我们想删除某个球员编号,但是如果没有单独保存比赛表的话,就会同时把比赛信息删除掉
  • 更新异常:如果我们调整了某个比赛时间,那么数据表所有的这个比赛的时间都得进行调整,不然就会出现同一场比赛但是时间不同的情况。

为了避免上述情况,我们可以把球员比赛表设计成下面的三张表。

表名
属性(字段)
球员player表
球员编号,姓名,年龄等属性
比赛game表
比赛编号,比赛时间,比赛场地等属性
球员比赛关系player_game表
球员编号,比赛编号,得分等属性

这样的话,每张数据表都符合第二范式,就避免了异常情况的发生
第二范式要求实体的属性完全依赖主关键字,如果存在不完全依赖,那么这个属性和主关键字的这一部分就应该分离处理形成一个新的实体,新实体和原来实体之间是一对多的关系

2.5第三范式(3NF)

  • 第三范式建立在已经满足第二范式的基础上
  • 数据表中的每一个非主键字段都和主键字段直接相关
  • 也就是说数据表中的所有非主键字段不能依赖于其他非主键字段
  • 这个规则的意思是所有非主属性之间不能有依赖关系,它们是互相独立的
  • 这里的主键可以拓展成为候选键
  • 三范式,MySQL,数据库,设计规范,mysql

三范式,MySQL,数据库,设计规范,mysql
三范式,MySQL,数据库,设计规范,mysql

2.6范式的优缺点

  • 优点:

    • 数据的标准化有助于消除数据库中的数据冗余
  • 第三范式通常被认为在性能,扩展性和数据完整性方面达到了最好的平衡

  • 缺点:

    • 降低了查询效率,因为范式等级越高,设计出来的表就越多,进行数据查询的时候就可能需要关联多张表,不仅代价昂贵,而且可能会使得一些索引失效

    • 范式只是提出设计的标标准,实际设计的时候,我们可能为了性能和读取效率违反范式的原则,通过增加少量的冗余或重复的数据来提高数据库的读取性能,减少关联查询,实现空间换时间的目的

3.反范式化

3.1概述

  • 遵循业务优先的原则
  • 首先满足业务需求,再进来减少冗余
  • 有时候我们想要对查询效率进行优化,反范式化也是一种优化思路,我们可以通过在数据表中增加冗余字段来提高数据库的读性能。
  • 三范式,MySQL,数据库,设计规范,mysql
    三范式,MySQL,数据库,设计规范,mysql

3.2 反范式的新问题

反范式虽然可以通过空间换实际,提升查询的效率,但是反范式也会带来一些新问题

  • 存储空间变大了
  • 一个表中字段做了修改,另外一个表中冗余字段也要同步进行修改,不然会导致数据不一致
  • 如果用存储过程了支持数据的更新,删除等操作,如果操作频繁,就会消耗系统资源
  • 在数据量小的情况下,反范式不能体现性能的优势,可能还会让数据库的设计更加复杂。

3.3反范式的适用场景

当冗余信息能大幅度提高查询效率的时候,我们才会采取反范式的优化。

增加冗余字段的建议
增加冗余冗余字段一定要符合下面的两个条件,满足下面的两个条件才可以考虑增加冗余字段
①这个冗余字段不需要经常进行修改
②这个冗余字段查询的时候不可或缺
三范式,MySQL,数据库,设计规范,mysql

4.BCNF(巴斯范式)

三范式,MySQL,数据库,设计规范,mysql
三范式,MySQL,数据库,设计规范,mysql
三范式,MySQL,数据库,设计规范,mysql
这个表符合第三范式
三范式,MySQL,数据库,设计规范,mysql
三范式,MySQL,数据库,设计规范,mysql文章来源地址https://www.toymoban.com/news/detail-784970.html

到了这里,关于数据库的三大范式的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 数据库—设计规范(依赖、范式、分解)

    如果在一个二维表中:Students(Sno , name, age),Sno 是这个表中的主键,所以对于其他属性来说,Sno决定name,Sno决定age,反过来则叫做name函数依赖于Sno… 定义:主码决定其他属性,其他属性函数依赖于主码 非平凡函数依赖 SC(Sno,Cno,Grade)这么一个表中解释,首先主码是Sno和Cno联合

    2024年02月12日
    浏览(35)
  • [MySQL]数据库原理1,三大范式,E-R图,DataBase,数据库管理系统(DBMS),Relationship,实体、属性、联系 映射基数,关系型数据库,联系的度数等——喵喵期末不挂科

    希望你开心,希望你健康,希望你幸福,希望你点赞! 最后的最后,关注喵,关注喵,关注喵,佬佬会看到更多有趣的博客哦!!! 喵喵喵,你对我真的很重要! 目录 前言 认识数据库 常见的数据库管理系统应用案例。       1.数据(Data)       2.数据库(DataBase ,简

    2024年02月04日
    浏览(36)
  • MySQL高级特性篇(6)-数据库设计模式与范式

    数据库是现代软件开发中非常重要的一环,而MySQL作为一种常用的关系型数据库管理系统,在数据库设计方面也有一些常见的模式和范式。本博客将介绍MySQL数据库设计模式与范式,让读者对MySQL数据库的设计有一个全面的了解。 一、数据库设计模式 数据库设计模式是数据库

    2024年02月22日
    浏览(33)
  • 数据库的设计规范:第一范式、第二范式、第三范式、巴斯范式

    目前关系型数据库有六种常见范式,按照范式级别,从低到高分别是: 第一范式(1NF)、第二范式(2NF)、第三范式(3NF)、巴斯-科德范式(BCNF)、第四范式(4NF)和第五范式(5NF,又称完美范式) 。 数据库的 范式设计越高阶,冗余度就越低 ,同时高阶的范式 一定符合

    2024年02月05日
    浏览(80)
  • MySQL笔记(一):设计范式、基础概念、数据库定义语言DDL

    MySQL是一种数据库管理系统 (DBMS),是基于客户机-服务器的数据库; 分为两个不同的部分, 服务器软件(MySQL DBMS)是负责所有数据访问和处理的一个文件,这个软件运行在称为数据库服务器的计算机上,与数据文件打交道; 客户机则是与用户打交道的软件,对于用户提出的

    2024年02月03日
    浏览(48)
  • 从0开始学习mysql 第十四课:数据库设计与三范式

    第十四课:数据库设计与三范式 学习目标 在本课中,你将学习关系数据库设计的三个基本范式,它们是用来规范数据库结构,减少数据冗余和改善数据完整性的准则。你将学习: 第一范式(1NF)的概念和实现 第二范式(2NF)的概念和实现 第三范式(3NF)的概念和实现 范式

    2024年01月23日
    浏览(36)
  • 【MySQL高级篇笔记-数据库的设计规范(中) 】

    此笔记为尚硅谷MySQL高级篇部分内容 目录 一、为什么要数据库设计  二、范式 1、范式简介 2、范式都包括哪些  3、键和相关属性的概念 4、第一范式(1st NF) 5、第二范式(2nd NF) 6、第三范式(3rd NF) 7、小结 三、反范式化 1、概述 2、 应用举例 3、反范式的新问题 4、反范式的适用

    2024年02月08日
    浏览(56)
  • 【MySQL索引与优化篇】数据库的设计规范

    在关系型数据库中,关于数据表设计的基本原则、规则就称为范式 。范式的英文名称是 Normal Form ,简称 NF 。它是英国人 E.F.Codd 在上个世纪70年代提出关系数据库模型后总结出来的。范式是关系数据库理论的基础,也是我们在设计数据库结构过程中所要遵循的 规则 和 指导方

    2024年02月05日
    浏览(54)
  • 数据库三大范式、BC范式、第四范式

    为了建立冗余较小、结构合理的数据库,设计数据库时必须遵循一定的规则。在关系型数据库中这种规则就称为范式。范式是符合某一种设计要求的总结。要想设计一个结构合理的关系型数据库,必须满足一定的范式。 第一范式是最基本的范式。 如果数据库表中的所有字段

    2024年01月18日
    浏览(32)
  • MySQL数据库之锁、范式

    锁是计算机协调多个进程或线程并发访问某一资源的机制。分为 全局锁、表级锁、行级锁。 1、定义 全局锁就是对整个数据库实例加锁,加锁后后续的DML的写语句, DDL语句,已经更新操作的事务提交语句都将被阻塞,整个实例就处于只读状态,即可以执行DQL语句,数据备份

    2024年02月11日
    浏览(36)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包