首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >查询微调

查询微调
EN

Stack Overflow用户
提问于 2012-12-24 16:51:03
回答 1查看 381关注 0票数 1

我有一个简单的查询,这需要大约7-8秒从数据库中检索数据,我想进一步微调到2-3秒。

表:

代码语言:javascript
运行
复制
UpdateDateTime | field1 | field2 |..... FieldN.

查询为:

代码语言:javascript
运行
复制
Select *  
from Table with (nolock)  
where UpdateDateTime Between D1 and D2  
Order By UpdateDateTIme  

我已经在UpdateDateTime上创建了聚集索引

可以进一步做些什么来提高其效率?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-12-24 16:52:12

减少返回的列数是显而易见的答案,然后在UpdateDateTIme上创建一个覆盖(非聚集)索引,并对其他选定的列执行INCLUDE

代码语言:javascript
运行
复制
CREATE NONCLUSTERED INDEX NC_MyCoveringIndex 
   ON Table(UpdateDateTime)
      INCLUDE (Col1, Col2, ..., ColN)

Ref

注意:创建一个包含表中所有列的覆盖范围很广的索引并不理想。

这在很大程度上取决于您的WHERE子句的选择性。如果它返回的行数(大约)大于表中行数的10%,那么优化器可能只会扫描聚集索引。

差不多就是这样。除此之外,您还需要查看您的硬件,以及您通过网络提取了多少数据。

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/14019145

复制
相关文章

相似问题

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