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
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
相关文章推荐
- Mysql in子查询效率慢的解决方法
- 执行SQL语句时出现问题操作必须使用一个可更新的查询错误的解决方法
- 解决SQL2000出现"无法执行查询,因为文件缺少或未注册。再次运行安装程序确保要求的文件已注册。"的方法
- ORA-14551: 无法在查询中执行 DML 操作 解决方法
- "执行SQL语句时出现问题操作必须使用一个可更新的查询"错误的解决方法
- SQL Server 数据库移植后不能执行大数据量查询 解决方法
- 试图执行的查询中不包含作为合计函数一部分的特定表达式的解决方法
- Oracle的SQL语句执行效率问题查找与解决方法
- 不能执行查询,因为一些文件丢失或未注册 解决方法
- sql 2000 无法执行查询,因为一些文件缺少或未注册"的解决方法
- easyUI的datagrid,当后台查询结果为空,不执行OnLoadSuccess方法的解决
- 关于Hibernate执行查询后会引发update操作的解决方法
- 试图执行的查询中不包含作为合计函数一部分的特定表达式的解决方法
- Oracle的SQL语句执行效率问题查找与解决方法
- Oracle执行计划 SQL语句执行效率问题查找与解决方法
- Microsoft Dynamics CRM 2011 当您在 大型数据集上执行 RetrieveMultiple 查询很慢的解决方法
- Microsoft Dynamics CRM 2011 当您在 大型数据集上执行 RetrieveMultiple 查询很慢的解决方法
- oracle的SQL语句执行效率问题查找与解决方法
- 查询mysql中执行效率低的sql语句的方法
- Microsoft Dynamics CRM 2011 当您在 大型数据集上执行 RetrieveMultiple 查询很慢的解决方法