当前位置:Gxlcms > mysql > Mysql的水平分表与垂直分表的讲解

Mysql的水平分表与垂直分表的讲解

时间:2021-07-01 10:21:17 帮助过:37人阅读

在我上一篇文章中说过,mysql语句的优化有局限性,mysql语句的优化都是围绕着索引去优化的,那么如果mysql中的索引也解决不了海量数据查询慢的状况,那么有了水平分表与垂直分表的出现(我就是记录一下自己的理解)

水平分表:

如上图所示:另外三张表表结构是一样的  只不过把数据进行分别存放在这三张表中,如果要insert 或者query 那么都需要对id进行取余 然后table名进行拼接,那么就是一张完整的table_name

但是如果我需要对name进行分表呢 或者对email呢?

那么就需要用MD5进行加密 因为MD5加密后是16进制  那么就就可以进行取余,思路同上。

垂直分表:

为什么需要进行垂直分表?

因为如果一张表中 有一个大字段 而且并不是必须要展示的或者不是当前需要用的  那么虽然没有刻意去查询  但是在根据id或者其他索引进行查询的时候就会把大字段一起查出来,会严重影响查询的性能,所以才有的垂直分表

详细请看下图:

以上就是水平分表和垂直分表的一种思路,水平有限 不足之处 请指出 谢谢

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。如果你想了解更多相关内容请查看下面相关链接

您可能感兴趣的文章:

  • MySQL存储文本和图片的方法
  • Ubuntu上mysql的安装及使用(通用版)
  • nodejs同步调用获取mysql数据时遇到的大坑
  • Mysql如何适当的添加索引介绍
  • 阿里云esc服务器Docker部署单节点Mysql的讲解
  • MySQL存储引擎MyISAM与InnoDB区别总结整理
  • Mysql忘记密码的几种解决方案
  • Tomcat+Mysql高并发配置优化讲解
  • 为什么MySQL数据库索引选择使用B+树?
  • 将图片储存在MySQL数据库中的几种方法

人气教程排行