zoukankan      html  css  js  c++  java
  • mysql数据库的水平分表与垂直分表实例讲解

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

    水平分表:

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

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

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

    垂直分表:

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

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

    详细请看下图:

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

  • 相关阅读:
    获得随机数
    Android Studio中的神操作
    Android Studio中的神操作
    我的github首页
    我的github首页
    初步尝试kotlin
    初步尝试kotlin
    创建自己的github博客
    js方法重载
    【HPU】[1014]【C语言训练】亲密数
  • 原文地址:https://www.cnblogs.com/liliuguang/p/10935763.html
Copyright © 2011-2022 走看看