首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQL Server 2005奇怪的查询性能

SQL Server 2005奇怪的查询性能
EN

Stack Overflow用户
提问于 2011-03-01 00:42:43
回答 3查看 237关注 0票数 2

我注意到我的数据库有一些性能问题。这样查询(仅作为示例):

代码语言:javascript
复制
SELECT * 
  FROM ActionHistory 
 WHERE ObjectId = @id"  

具有不同读取和持续时间的随机...executes。ObjectId是外键,上面有索引。

使用SQL Profiler我发现,有时结果是:5次读取,0持续时间,但在另一种情况下:5次读取,200持续时间。如此长的持续时间是偶然发生的。

我在WCF中使用分布式事务。当我是当时唯一的用户时,我得到了这样的结果,所以它很可能不是锁或其他东西。

这种行为的原因是什么:读取次数少,但查询持续时间长?

EN

回答 3

Stack Overflow用户

发布于 2011-03-01 00:53:50

一般来说,分布式事务是非常昂贵的。尝试在您的环境中禁用分布式事务,看看这是否会改变什么。

票数 1
EN

Stack Overflow用户

发布于 2011-03-01 00:50:26

由于查询每次都是完全相同的,读取也是相同的,因此很可能是由于锁定。有时,另一个查询正在执行,并且可能锁定了需要访问的记录。等待锁被释放会导致速度减慢。

使用SQL事件探查器比较查询的开始/停止时间,可以确定可能导致锁定的重叠查询。

这并不是一个问题的迹象,只是对你所看到的差异的一个解释。

票数 0
EN

Stack Overflow用户

发布于 2011-03-01 01:47:14

在数据库中启用读取提交的快照:

代码语言:javascript
复制
ALTER DATABASE ... SET READ_COMMITTED_SNAPSHOT ON;

这将奇迹般地将默认的读-提交隔离下发生的读取更改为快照读取,这不会受到锁的阻碍。详情请参见Choosing Row Versioning-based Isolation Levels,其中包括启用快照读取所导致的运行时资源使用情况。

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

https://stackoverflow.com/questions/5144831

复制
相关文章

相似问题

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