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

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

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

1、什么是设计范式?

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

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

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

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

3、三范式都有哪些?

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

在这里插入图片描述

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

在这里插入图片描述

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

在这里插入图片描述

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

在这里插入图片描述

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

在这里插入图片描述

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

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

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

一对一怎么设计?

第一种方案:主键共享

在这里插入图片描述

第二种方案:外键唯一

在这里插入图片描述

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

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

相关文章

  • MySQL常用时间函数详解(推荐)

    MySQL常用时间函数详解(推荐)

    下面小编就为大家带来一篇MySQL常用时间函数详解(推荐)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-06-06
  • 经典mysql连接查询例题

    经典mysql连接查询例题

    本文通过一个有趣的例子向我们介绍了mysql连接查询,采用了子查询和连接查询混合和多次连接查询,需要的朋友可以参考下
    2015-07-07
  • Mac 将mysql路径加入环境变量的方法

    Mac 将mysql路径加入环境变量的方法

    这篇文章主要介绍了Mac如何将mysql路径加入环境变量,有需要的朋友好按照下面的步骤操作即可
    2014-07-07
  • Mysql my.ini 配置文件详解

    Mysql my.ini 配置文件详解

    Mysql my.ini 配置文件详解
    2009-06-06
  • Ubuntu中MySQL的参数文件my.cnf示例详析

    Ubuntu中MySQL的参数文件my.cnf示例详析

    这篇文章主要给大家介绍了关于Ubuntu中MySQL的参数文件my.cnf的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用mysql具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-10-10
  • 允许任意IP访问mysql数据库的方法详解

    允许任意IP访问mysql数据库的方法详解

    MYSQL默认只能本地连接,即127.0.0.1和localhost,其他主机IP无法访问数据库,那么如何允许任意IP访问mysql数据库,所以本文小编将给大家介绍允许任意IP访问mysql数据库的方法,文中通过代码示例介绍的非常详细,需要的朋友可以参考下
    2024-01-01
  • MySQL新手入门进阶语句汇总

    MySQL新手入门进阶语句汇总

    这篇文章主要给大家介绍了关于MySQL新手入门进阶语句的相关资料,总结分析了MySQL数据库常用的查询、条件查询、排序、连接查询、子查询等相关操作技巧,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2022-09-09
  • PHP使用mysqli扩展连接MySQL数据库

    PHP使用mysqli扩展连接MySQL数据库

    这篇文章主要介绍了PHP使用mysqli扩展连接MySQL数据库,需要的朋友可以参考下
    2014-08-08
  • MYSQL修改所有表的存储引擎格式语句

    MYSQL修改所有表的存储引擎格式语句

    MYSQL如何修改所有表的存储引擎格式,或许下面的sql语句对大家有所帮助
    2013-08-08
  • mysql 5.7.30安装配置方法图文教程

    mysql 5.7.30安装配置方法图文教程

    这篇文章主要为大家分享了mysql 5.7.30安装配置方法图文教程,感兴趣的小伙伴们可以参考一下
    2016-05-05

最新评论