您的位置:首页 > 数据库 > MySQL

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

2012-06-05 10:50 106 查看
因为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
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐