sharding-jdbc绑定表的解析
2021-11-19 本文已影响0人
Britney_z
例如我们执行这个sql: SELECT o.* FROM t_order o JOIN t_order_item i ON o.order_id=i.order_id and o.user_id IN(10,16),
我们看看设置绑定表规则:sharding.jdbc.config.sharding.binding-tables[0]=t_order,t_order_item
看看是如何改写sql的?
下面路由到两个TableUnits,然后遍历两个TableUnits
data:image/s3,"s3://crabby-images/8bfea/8bfea008dfc9c91956c350222a5713f8cbe86f2c" alt=""
我们看下SQLRewriteEngine 的getTableTokens方法,查找表绑定规则
data:image/s3,"s3://crabby-images/c1ede/c1edeb974ea0cc40c5576285811cb53cdf8a8d02" alt=""
我们找t_order_10绑定的对应的t_order_item_10
data:image/s3,"s3://crabby-images/8c241/8c241d47d06b39ee00c11135e9b4dfca6fe06b76" alt=""
data:image/s3,"s3://crabby-images/5394a/5394a3d5ba65220c2b913e6d529b6bb502d75708" alt=""
如果不设置绑定表规则,tableunit
data:image/s3,"s3://crabby-images/31e3b/31e3b9c87bf0ad3816369c60365d80f878a08fc0" alt=""
笛卡尔路由sql
data:image/s3,"s3://crabby-images/9ce83/9ce8350cf746c068a20bad6f60dacc1984693ec2" alt=""