垂直分库
单库:客户相关表、合同相关表、放款相关表等等
分库:客户数据库、合同数据库、放款数据库等等
涉及到问题:
1.联表查询
字段冗余:将经常使用的客户字段放到合同库中,避免跨库查询
数据同步
广播表(全局表)
绑定表(ER表):父表id和子表中有相同父表id的数据放到一个库
系统层组装
2.分布式事务
工具:Atomikos 、LCN、 Seata
水平分库分表
客户表分成多个数据库:客户表DB1、客户表DB2
水平分表带来的问题?
1.联表查询的问题
2.翻页查询
3.全局ID,auto increament 自增id重复
4.拆分规则的选择
1亿数据怎么分到3个node?连续分片、随机分片
均匀、查询方便、扩容、迁移简单
随机
取模
基于范围
枚举:男女放在不同库
哈希
一致性哈希
分库分表后,程序如何访问数据库
编码层 abstractRoutingDataSource 难以维护
框架层 Mybatis
驱动层 Sharding-JDBC
代理层 Mycat
服务层 一个特殊的SQL版本