MySQL系列数据库设计三范式教程示例

 更新时间:2021年10月26日 10:44:40   作者:数据分析与统计学之美  
这篇文章主要为大家介绍了MySQL系列之数据库设计三范式的教程示例讲解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步

一、数据库设计三范式相关知识说明

1、什么是设计范式?

设计表的依据,按照这三个范式设计出来的表,不会出现数据的冗余。

2、为什么要学习数据库的三个范式?

数据库的设计范式是数据库设计所需要满足的规范,满足这些规范的数据库是简洁的、结构明晰的,同时,不会发生插入(insert)、删除(delete)和更新(update)操作异常。反之则是乱七八糟,不仅给数据库的编程人员制造麻烦,而且面目可憎,可能存储了大量不需要的冗余信息。

我们数据分析师虽然不需要自己去设计数据库,但是了解数据库的三个范式,对于我们后面进行表的理解能够有一定的帮助。

3、三范式都有哪些?

1)第一范式:任何一张表都应该有主键,并且每一个字段原子性不可再分。

在这里插入图片描述

2)第二范式:建立在第一范式基础上的,另外要求所有非主键字段完全依赖主键,不能 产生部分依赖。

在这里插入图片描述

解决办法:多对多,三张表,关系表两个外键。

在这里插入图片描述

3)第三范式:建立在第二范式的基础之上,所有非主键字段直接依赖主键,不能产生传递依赖。

在这里插入图片描述

解决办法:一对多,两张表,多的表加外键。

在这里插入图片描述

注意:牢记上述蓝色部分的两句话。

提醒:在实际的开发中,以满足客户的需求为主,有的时候会拿冗余换执行速度。

二、数据库表的经典设计方案

一对一怎么设计?

第一种方案:主键共享

在这里插入图片描述

第二种方案:外键唯一

在这里插入图片描述

注意:外键唯一这种情况,有点像上面讲述的多对多的情形,当外键字段加了一个
unique限制条件后,就变成一对一了。

以上就是MySQL系列数据库设计三范式教程示例的详细内容,更多关于MySQL数据库设计三范式的资料请关注脚本之家其它相关文章!

相关文章

  • MySQL 8.0 之不可见列的基本操作

    MySQL 8.0 之不可见列的基本操作

    MySQL8.0.23之后引入了不可见列,今天我们来说说这个特性的基本使用,感兴趣的朋友可以了解下
    2021-05-05
  • Mysql主从延时图解方法

    Mysql主从延时图解方法

    我们知道,一个服务器开放N个链接给客户端连接的,就会有大并发的更新操作,但是从服务器的里面读取binlog线程得仅有一个,当某个SQL在从服务器上执行的时间稍长 或由某个SQL要锁表就会导致主服务器的SQL大量积压,未被同步到从服务器,就导致了主从不一致,也就是主从延迟
    2022-01-01
  • mybatis分页插件pageHelper详解及简单实例

    mybatis分页插件pageHelper详解及简单实例

    这篇文章主要介绍了mybatis分页插件pageHelper详解及简单实例的相关资料,需要的朋友可以参考下
    2017-05-05
  • Django创建项目+连通mysql的操作方法

    Django创建项目+连通mysql的操作方法

    这篇文章主要介绍了Django创建项目+连通mysql的操作方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-03-03
  • 浅谈为什么MySQL不推荐使用子查询和join

    浅谈为什么MySQL不推荐使用子查询和join

    这篇文章主要介绍了浅谈为什么MySQL不推荐使用子查询和join,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-03-03
  • percona-toolkit之pt-kill 杀掉mysql查询或连接的方法

    percona-toolkit之pt-kill 杀掉mysql查询或连接的方法

    本文主要描述了percona-toolkit中pt-kill的 使用实例 ,及 一些重要参数的介绍,需要的朋友可以参考下
    2016-04-04
  • MySQL中浮点型转字符型可能会遇的问题详解

    MySQL中浮点型转字符型可能会遇的问题详解

    类型转换是我们日常开发中经常会遇到的一个需求,最近在将浮点型转换成字符型的时候就遇到了一个问题,所以总结分享出来,下面这篇文章主要给大家介绍了MySQL中关于浮点型转字符型可能遇到的问题的相关资料,需要的朋友可以参考下。
    2017-09-09
  • mysql过滤复制思路详解

    mysql过滤复制思路详解

    这篇文章主要介绍了mysql过滤复制的实现思路,主要讲解了两种思路,一种是在主库的binlog上实现另一种是从库的sql线程上实现,具体实现过程跟随小编一起看看吧
    2021-08-08
  • MySQL存储引擎 InnoDB与MyISAM的区别

    MySQL存储引擎 InnoDB与MyISAM的区别

    InnoDB和MyISAM是许多人在使用MySQL时最常用的两个表类型,这两个表类型各有优劣,视具体应用而定。
    2014-03-03
  • 关于mysql合并表的详细介绍

    关于mysql合并表的详细介绍

    本篇文章是对mysql中的合并表进行了详细的分析介绍,需要的朋友参考下
    2013-06-06

最新评论