专栏首页java开发的那点事Mysql业务设计(逻辑设计)

Mysql业务设计(逻辑设计)

逻辑设计

数据库设计三大范式

数据库设计第一大范式

  • 数据库表中所有的字段都只具有单一属性
  • 单一属性的列是由基本数据类型所构成
  • 设计出来的表都是简单的二维表

 数据库设计的第二大范式

要求表中只有一个业务主键,也就是说符合第二范式的表不能存在非主键列,只对部分主键的依赖关系

 数据库设计的第三大范式

指每一个非非主属性既不部分依赖于也不传递依赖于业务主键,也就是在第二范式的基础上相处了非主键对主键的传递依赖

反范式化设计

为啥要有这个东西呢,就是因为如果过分的依赖于三大范式,设计出来的表虽然很符合规范,但是SQL的查询性能将会很差,所以才有了反范式设计

什么叫反范式化设计:

  • 反范式化是针对范式化而言的,在前面介绍的三大范式
  • 所谓的反范式化就是为了性能和读取效率的考虑而适当的对数据库设计范式的要求进行违反
  • 允许存在少量冗余,换句话来说反范式化就是用空间换时间

逻辑设计总结

不能完全按照范式的要求进行设计

考虑以后如何使用表

范式化设计优缺点

优点:

可以尽量的减少数据冗余

范式化的更新操作比反范式化更快

范式化的表通常比反范式化的表要小

缺点:

对于查询需要多个表进行关联

更难进行索引优化

反范式化设计的优缺点:

优点:

可以减少表的关联

可以更好的进行索引优化

缺点:

存在数据冗余及数据维护异常

对数据修改需要更多的成本

作者:彼岸舞

时间:2020\07\08

内容关于:Mysql

本文来源于网络,只做技术分享,一概不负任何责任

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • java8提取对象集合中的一项属性

      java都快出15了,我才开始写8,感觉跟不上时代了[捂脸],如果使用循环的方法提取,比较复杂,代码较多,尝试使用java8提取

    彼岸舞
  • EasyPoi导出Excel

    这几天一直在忙工作中的事情,在工作中有一个问题,可能是因为刚开始接触这个EasyPoi,对其也没有太多的理解,在项目中就使用了,有一个需求,是要导出项目中所有的...

    彼岸舞
  • ORA-12519: TNS:no appropriate service handler found 解决方法

      今天客户在使用导入Excel功能时,由于底层的数据库连接层框架是自己公司研发的,导致出现问题

    彼岸舞
  • 数据库学习

    【不满足第一范式】:1.主键重复。2. StuInfo字段可以再分 |StuId(主键学号)| StuName (姓名)| StuIn...

    李郑
  • 都快0202年了,还不会Linux 基础命令?

    “rm -rf” 引发的血案都在菜鸟程序员中经常出现,初初入行的前后端们基础不扎实。

    前端劝退师
  • 如何做好需求收集[来之《程序员》第2期]

    项目前期需求收集过程的效果好坏,会对软件产品的最终质量产生直接的影响。如何收集好需求,本文作者给出了一条行之有效的实际操作途径。 什么是需求收集? 需求收集,...

    阿新
  • 支持多用户web终端实现及安全保障(nodejs)

    背景 terminal(命令行)作为本地IDE普遍拥有的功能,对项目的git操作以及文件操作有着非常强大的支持。对于WebIDE,在没有web伪终端的情况...

    欲休
  • Linux平台 Oracle 10gR2(10.2.0.5)RAC安装 Part1:准备工作

    Linux平台 Oracle 10gR2(10.2.0.5)RAC安装 Part1:准备工作

    Alfred Zhao
  • SOFAJRaft—初次使用

    SOFAJRaft 是基于 Raft 算法的生产级高性能 Java 实现,支持 MULTI-RAFT-GROUP。应用场景有 Leader 选举、分布式锁服务、...

    luozhiyun
  • SOFAJRaft—初次使用

    SOFAJRaft 是基于 Raft 算法的生产级高性能 Java 实现,支持 MULTI-RAFT-GROUP。应用场景有 Leader 选举、分布式锁服务、...

    luozhiyun

扫码关注云+社区

领取腾讯云代金券