mysql 水平分割

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

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

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取模,把模的值拿到就可以获取到具体添加到哪张表。往里面添加数据。

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

 

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