mysql 水平分割

在面对海量数据的情况下,索引当然是其中一种优化手段,索引也会占用开销、磁盘等,除了索引还可以进行表的分割

首先我先画一个图,一个思路

图划得有点丑。

当我们比如要取id为1000的user,1000%4=0  那我们取QQ0这张表里面id为1000的的user,当然4张表的表结构都是一样的。只是数据不一样而已。当我们添加user的时候,就直接往QQID里面添加一条记录,QQID的表只有一个字段就可以,id设置为自增长,就能获取到当前user的id值。把这个id值取到,不管是mybatis还是hibernate等框架以及mysql都可以获取到当前id的值,然后把添加的user的id值在id%4取模,把模的值拿到就可以获取到具体添加到哪张表。往里面添加数据。

这个就是水平分割:按记录进分分割,不同的记录可以分开保存,每个子表的列数相同。

 

当然不同业务也是不同的,也有可能实际业务按时间、按天等,但思路其实差不多

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值