需求背景:已经有几千万的注册用户数据,而我们数据库一张表上限大约是5000W条数据,而我们往往也不能真的全部占用,这就要必须对用户数据分库分表了。分表分为水平拆分和垂直拆分,这里我写的就是一个关于水平拆分的demo。
实验:
工具和环境:jdk1.8, idea, sharding-jdbc, mybatis, postgresql(数据库,因为目前公司用的这个数据库,所以拿这个做的),springboot,maven
思路:对用户表(t_user_info)进行拆分。
1.我创建2张表t_user_info_0和t_user_info_1,这2个表就是t_user_info将拆分成的表。
2.我们插入数据时如何保证每条数据进入这2个表的机率时平均的呢?我们在表中加入一个字段role_id来路由一条插入数据将进入哪张表,我采取的方法是,创建一个自增序列表seq_t_user_role_id,每次插入一条数据的时候先去获取序列号,然后在将获取的值与我要分的表的数量取余(seq_id%table_count),而得到的值就是我们要插入表名的后缀。例如1%2=1,所以是表t_user_info_1,2%2=0 对应的表t_user_info_0.
实战:
1. 创建分表和序列
data:image/s3,"s3://crabby-images/de923/de923abefe328548f5d05ccdf75c3a7a8ef3944f" alt=""
2.用idea快速搭建一个可运行的springboot的web项目,项目名demo(取名障碍症,请原谅),下面是我的包结构。
data:image/s3,"s3://crabby-images/2cbbe/2cbbeb6adbbba2cbbd49bf9dd7e1b95266dcefa8" alt=""
3.加入数据库等依赖包。
data:image/s3,"s3://crabby-images/6fb05/6fb0545a0d6ba782279f95e323ffb25c0e23e37e" alt=""
4.配置sharding-jdbc(具体sharding配置信息可以看sharding的官网):
data:image/s3,"s3://crabby-images/0a3ad/0a3ad45b7d6d8e8591b614945bff1b87d5207d15" alt=""
因为sharding-jdbc-spring-boot-starter包在启动时会自动帮我们创建datasource:
data:image/s3,"s3://crabby-images/bf573/bf573d86c631d45bdfc6e04f69370c298d161c09" alt=""
配置sqlSessionFactory:
data:image/s3,"s3://crabby-images/539a3/539a348490ee675c85e8defa4972e8967c92d924" alt=""
然后贴上超级简单的实现代码:
data:image/s3,"s3://crabby-images/d158e/d158eed32bec9e59fd9d129ef7bff88a86d68acb" alt=""
data:image/s3,"s3://crabby-images/a7da7/a7da7cfbad49d4b38e3f5623628fdecdcb4b5734" alt=""
data:image/s3,"s3://crabby-images/be361/be361f7cc2773c8530f2fa817e52b35c7ebe3db1" alt=""
data:image/s3,"s3://crabby-images/4416e/4416ee114f7fd1490ae61f9de6b2c187bee8e410" alt=""
最后贴上项目源码地址:https://gitee.com/yijy/partitiontabledemo。
请各位大佬轻喷,欢迎留言交流!
网友评论