分库分表是什么?

分库分表是什么?

分库分表就是将本应该存到一个库的,一个表中的数据分到多个库,多个表进行存储,将一个库分成多个库,将一个表分成多个表

为什么要分库分表?

当数据库存储大量的数据时,(出于性能考虑mysql的单表数据量不要超过一千万),查询的速率会随着数据的增多变慢,这样会增加数据库的压力。所以才会选择进行分库分表。

分库分表的方式都有什么?

分库分表的方式有垂直拆分水平拆分(垂直拆分为主,水平拆分为辅)。另外还有一种方式,通常与拆分结合使用,叫做读写分离

1 垂直拆分:

  • a 垂直拆分是什么
    就是将一个表中的字段分成2大帮派(也叫做冷热分离,动静分离),例如:按常用(热的,动的数据)与不常用(冷的,静的数据)来分,一帮派是常用的,另一帮派是不常用的,举个栗子~商品表中的名称,价格和详情字段,就可以按照常用和不常用来化分,咱们浏览商品时看得最多的是名称和价格,而对这个商品有意思才会点进去看详情。这就是为什么将商品表分成2大帮派的根源,数据库也是如此分的。

  • b 垂直拆分优点
    使行数据变小,便于实现动静分离,冷热分离的数据库设计模式,数据维护简单。

  • c 垂直拆分缺点
    因为是按字段分割的,所以会出现主键冗余,依然出现单表数据量过大的问题,还要水平拆分。

2 水平拆分:

  • a 水平拆分是什么
    就是将一张表水平切分,分成多个表,(可以按照id,时间,hash分片等等)例如:一个表中有10条数据,就可以分成2张表,每张表中有5条数据,数据库也是如此分的。

  • b 水平拆分优点
    单库单表的数据保持在一定的量级,有助于性能的提高。提高了系统的稳定性和负载能力

  • c 水平拆分缺点
    切分后,数据是分散的,跨库Join性能较差。(水平拆库时读取数据时会出现多个库并查的现象,所以在分库之前一定要设计好。eg:设计时后期如果需要查某段时间的可以将时间字段作为分库,分表标准,看具体需求)

  • 另外补充一个点:路由()只存在于水平拆分中 **
    路由是什么?你可以将他看成你登陆时可以通过你的Id找到你位于拿哪个库的过程~,那在这个过程中他的id又是经历多少
    波折**(工具)到达他位于的库的呢,这个波折就类似算法,算式。假如我们规定他就必须按照{id % 2} 这个波折去到他的库,这样,他要想到达库,就得让他的id对2取余,才告诉他位于哪个库。这个过程就叫做路由,至于他用什么工具(经历了多少波折)度过就由你来定喽~(要想过此路,就得按我说的来)

3读写分离

  • 因为通常操作数据库都是查询远多于存储,所以把写和读分开,让他们存在不同的数据库中,通常将存储的数据库叫作主库,进行读的数据库叫做从库,当然,我们存入主库的数据会更新到从库上,保持数据的一致性。
  • 注意:进行操作时(如果还和分库分表结合,而且按照id分库分表时,这时添加数据的id是从外部添加的(在外部,有生成自增id的2种算法:UUID和SNOWFLAKE),因为如果利用数据库的自增id添加时,会出现多个库多个表主键重复的现象,而且也会出现通过id分库分表失败(原因:从java向数据库添加过程中id是以0添加的,而数据库又设置了从1开始自增长,所以进行判断分库分表的id值和实际添加到数据库中的id值不一样
参考的大神链接

https://blog.csdn.net/CrankZ/article/details/84679742

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值