Mysql分库分表

垂直分库

单库:客户相关表、合同相关表、放款相关表等等
分库:客户数据库、合同数据库、放款数据库等等
涉及到问题:
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版本

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值