因为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
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