总结数据库分/分表常见的几种路由规则

分片路由

  1. 直接路由:只针对分库不分表的情况,可以避免SQL解析和之后的结果归并;
  2. 标准路由:不包括关联查询或者只包括绑定表(主表和子表有相同的sharding key)之间的关联查询;一般包括=,in和between and三种情况;
  3. 笛卡尔积:非绑定表之间的关联查询;性能最差;

广播路由

查询中不包括sharding key,这个是需要做全局扫描和结果归并的;

  1. 全库路由:主要包括对数据库的操作,比如SET指令等TCL指令;
  2. 全库表路由:包括不带分片键的DQL和DML,以及DDL等;
  3. 全实例路由:用于DCL操作,授权语句针对的是数据库的实例;
  4. 单播路由:用于获取某一真实表信息的场景,它仅需要从任意库中的任意真实表中获取数据即可,比如desc table;
  5. 阻断路由:用于屏蔽SQL对数据库的操作,比如use database;

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值