mysql loose_MySQL5.6 Semi join优化策略之LooseScan 策略

8月 24, 2014 |

Nix.Huang

LooseScan 策略

LooseScan 策略是semi join子查询的一种执行策略

比如:

select * from Country

where

Country.code in (select country_code from Satellite)

查找拥有卫星的国家(为了简化,不考虑多个国家共同拥有一个卫星),

假设Satellite. country_code有索引,那么我们可以按照国家编码的顺序获取卫星数据:如图:

bbc9d6d0aab14dea300828900466f99a.png

LooseScan策略不是真的需要排序,它需要的是分组,在上面的图中,卫星以国家分组,比如澳大利亚拥有的卫星在一块,没有混合其他国家的卫星,这使得从一个组中选择一颗卫星更容易,你可以用其join 国家而不会重复:

bb3103afcf9cd285c8c7a2902a8de984.png

explain select * from Country where Country.code in (select country_code from Satellite);

当然为了显示,我删除了一些列,

looseScan 可以通过设置optimizer_switch变量的loosescan=off标识来关闭loosescan优化

LooseScan 和FirstMatch策略的区别:

对于格式为:

SELECT ... FROM outer_tables WHERE expr IN (SELECT ... FROM inner_tables ...)的semi join

如果对该sql 执行Pullout消除子查询后,不能转换为simple 查询类型,如果全扫描out_tables的代价小于全扫描inner_tables,那么本次就使用FirstMatch策略,反之,使用LooseScan策略

参考地址

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值