首页 > 数据库技术 > 详细

SQL疑难杂症【4 】大量数据查询的时候避免子查询

时间:2015-05-21 10:21:26      阅读:246      评论:0      收藏:0      [点我收藏+]

前几天发现系统变得很慢,在Profiler里面发现有的SQL执行了几十秒才返回结果,当时的SQL如下:

技术分享

 

可以看得出来,在652行用了子查询,恰巧目标表(QS_WIP)中的记录数为100000000+,通过如下SQL可以得到:

SELECT ROWS FROM SYSINDEXES WHERE ID=OBJECT_ID(‘QS_WIP‘) AND INDID <2

大量的数据导致子查询的效率非常慢,应用系统一度提示"time out",经过优化,改为如下写法,执行效率明显提升:

技术分享

 

先将子查询里面的内容提取出来作为一个临时表,再次join的时候就快了。

SQL疑难杂症【4 】大量数据查询的时候避免子查询

原文:http://www.cnblogs.com/allen0118/p/4518816.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!