首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >简单的select查询花费的时间太长

简单的select查询花费的时间太长
EN

Stack Overflow用户
提问于 2012-04-30 14:41:34
回答 1查看 3.8K关注 0票数 0

我有一个表,某个星期大约有18k行,另一个星期有22k行。

我使用视图和索引来检索数据,如下所示

代码语言:javascript
复制
SELECT TOP 100 * FROM my_view 
WHERE timestamp BETWEEN @date1 AND
@date2

但不知何故,22k的那一周检索数据更快(大约3-5秒),而另一周至少需要一分钟。这会导致我的wcf超时。我遗漏了什么?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-04-30 18:38:02

在时间戳字段上应用索引。

如果你已经有了时间戳的索引,那么在执行计划中检查这个查询所使用的索引。

仅当查询涉及连接表,并且用于连接其他表的列与多个索引匹配时,索引提示才会起作用。在这种情况下,数据库引擎可能会选择使用一个索引来进行连接,根据调查,您可能知道如果使用另一个索引,查询的性能会更好。在这种情况下,您需要提供索引提示,告诉数据库引擎要使用哪个索引。

示例代码使用索引提示:

代码语言:javascript
复制
select [Order].[OrgId], [OrderDetail].[ProductId]
  from [Order] 
 inner join [OrderDetail] **with(index(IX_OrderDetail_OrderId))** on [Order].[OrderId] = [OrderDetail].[OrderId]
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/10379519

复制
相关文章

相似问题

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