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

来源:互联网 发布:淘宝网怎么发帖 编辑:程序博客网 时间:2024/04/28 21:49
因为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
原创粉丝点击