首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用group和join子句优化SQL Server查询性能

使用group和join子句优化SQL Server查询性能
EN

Stack Overflow用户
提问于 2013-12-20 10:00:15
回答 2查看 803关注 0票数 0

我们一直在经历对作业性能的担忧,幸运的是,我可以找到导致缓慢的查询。

代码语言:javascript
复制
select   name from Student a, Student_Temp b
where a.id = b.id and
a.name in (select name from Student
group by name having count(*) = @sno)
group by a.name having count(*) = @sno
OPTION (MERGE JOIN, LOOP JOIN)

这个特定的查询多次被反复调用,降低了性能。

Student表有800万条记录,Student_temp每次在迭代过程中接收5-20条记录。Student表具有复合主键on ( idname)和sno = No of Student_Temp中的记录。

我的问题如下: 1)为什么这个查询会显示性能问题。( 2)你们能给出一种更有效的方式来写这篇文章吗?

提前谢谢!

EN

回答 2

Stack Overflow用户

发布于 2013-12-20 10:19:59

这是不必要地重复同样的逻辑。你真的只想:

  • 也存在于Student_temp中的学生
  • 有没有什么名字?

试试这个:

代码语言:javascript
复制
SELECT
    name
FROM
    Student a JOIN
    Student_Temp b ON a.id = b.id
GROUP BY
    name
HAVING
    count(*) = @sno
票数 1
EN

Stack Overflow用户

发布于 2013-12-20 12:44:13

,给你,

代码语言:javascript
复制
select   name 
from Student a
inner join Student_Temp b
on a.id = b.id
group by a.name 
HAVING COUNT(*) = @sno
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/20700942

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档