mysql in子查询执行效率慢的解决方法

因为MySQL在处理子查询的时候是不够好,在有些情况下执行效率真的很慢。我在MySQL 5.1.42 和 MySQL 5.5.19 都进行了尝试,都有这个问题。

1.将in子查询改为join连接查询,速度为会明显提升,以下举例,以100条记录为例:

用in子查询测试:

select 商品信息id,商品编码,商品名称,总公司售价,库存,分公司售价
FROM
(
SELECT 商品信息.商品信息id,商品信息.商品编码,商品信息.商品名称,商品信息.零售价 as 总公司售价,ZP01.库存,ZP01.零售价 as 分公司售价
FROM 商品信息,ZP01
where ZP01.商品信息ID=商品信息.商品信息ID  and 商品信息.类别ID in (select 部类ID from 商品部类信息 where FIND_IN_SET(部类ID, getChildLst(30022)))  and 商品信息.定价标记='已核价'
limit 0,100
) A

此查询执行时间为7.658s。可见执行速度真的是很慢,才100条记录。

改为用join连接查询测试:

select 商品信息id,商品编码,商品名称,总公司售价,库存,分公司售价
FROM
(
SELECT 商品信息.商品信息id,商品信息.商品编码,商品信息.商品名称,商品信息.零售价 as 总公司售价,ZP01.库存,ZP01.零售价 as 分公司售价
FROM 商品信息,ZP01,(select 部类ID from 商品部类信息 where FIND_IN_SET(部类ID, getChildLst(30022))) T
where ZP01.商品信息ID=商品信息.商品信息ID  and 商品信息.类别ID=T.部类ID  and 商品信息.定价标记='已核价'
limit 0,100
) A

此查询执行时间为0.140s。这次执行速度还比较正常,可以接受。

另一种解决方法:

select 商品信息id,商品编码,商品名称,总公司售价,库存,分公司售价
FROM
(
SELECT 商品信息.商品信息id,商品信息.商品编码,商品信息.商品名称,商品信息.零售价 as 总公司售价,ZP01.库存,ZP01.零售价 as 分公司售价
FROM 商品信息,ZP01
where ZP01.商品信息ID=商品信息.商品信息ID  and 商品信息.类别ID in (select 部类ID from (select 部类ID from 商品部类信息 where FIND_IN_SET(部类ID, getChildLst(30022))) as T)  and 商品信息.定价标记='已核价'
limit 0,100
) A

此查询执行时间为0.188s。这次执行速度也还比较正常,也可以接受。


参考资料:
http://www.cnblogs.com/xh831213/archive/2012/05/09/2491272.html
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值