• 分库分表是什么,什么情况下需要用分库分表


    1、什么是分库分表?

    顾名思义,即把存于一个库的数据分散到多个库中,把存于一个表的数据分散到多个表中。

    2、什么情况下需要分库分表?

    当一个数据库被创建之后,随着时间的推移和业务量的增加,数据库中表以及表中的数据量就会越来越多,就有可能出现两种弊端:(1)数据库的存储资源是有限的,其负载能力也是有限的,数据的大量积累肯定会导致其处理数据的能力下降;(2)数据量越多,那么对数据的增删改查操作的开销也会越来越大,所以,当出现如上两种情况,分库分表势在必行。

    3、分库分表的方式

    (1)垂直切分

    适用场景:如果是因为表的个数多而让数据多,可以按照功能划分,把联系密切的表切分出来放在同一个库中(分库);

    如果表的字段太多,可以以列为出发点,将字段进行拆分(分表);

    (2)水平切分

    适用场景:如果是因为表中的数据量过于庞大,则可以采用水平切分,按照某种约定好的规则将数据切分到不同的数据库中;

    必须要根据当前数据库的情况做出合适的选择,也可以将两种情况结合在一起。

    4、如何联合查找?

    分库分表的结果会使数据分散,不好查询,主要有两种查询方式:

    (1)、分步查:先查找主表,然后得到关联表的id,再发起请求得到关联数据;

    (2)、联合查:同时发起多个查询请求,然后将所有的结果集合起来。
     

  • 相关阅读:
    PL/SQL 入门
    Nginx 安装和配置
    MySql 优化方案
    类加载器(ClassLoader)
    动态代理入门
    Servlet 3.0 介绍
    反射加强(一)
    Python(1)—is和==区别
    代码题(10)— 验证二叉搜索树、二叉搜索树的最近公共祖先
    代码题(9)— 二叉树的最大、最小深度、平衡二叉树
  • 原文地址:https://www.cnblogs.com/strawqqhat/p/10602158.html
Copyright © 2020-2023  润新知