首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在读取DMV时设置未提交读

在读取DMV时设置未提交读
EN

Database Administration用户
提问于 2013-01-17 12:04:10
回答 2查看 989关注 0票数 12

在阅读系统DMV之前,我见过一些人打电话给SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED

假设您没有在同一事务中混合对DMV和表的调用,那么是否有理由这样做?

促使我提出这个问题的原因是在一个将sys.dm_exec_query_statssys.dm_exec_sql_textsys.dm_exec_query_plan连接起来的查询中看到了这个问题。

EN

回答 2

Database Administration用户

回答已采纳

发布于 2013-01-17 13:07:03

当其中一个人用这种方式编写演示DMV查询时,我将解释原因。

如果你只是在询问汽车司机,有什么关系吗?不是的。但迟早,您将使用您的DMV脚本之一,并将其连接到sys.databases或sys.tables或其他系统对象,以便获得更多有关您正在查看的内容的信息。如果您没有在那里读取未提交的内容,则可能会被其他查询阻塞,并阻塞其他查询。我多次被这种情况所激怒,所以每当我做任何诊断工作时,我都会默认使用READ。

票数 11
EN

Database Administration用户

发布于 2013-01-17 12:45:49

我看不出这有什么区别。

如果我尝试下面的操作并比较winmerge中这两个隔离级别的锁输出,它们是完全相同的(甚至把它放到SERIALIZABLE上也不会改变输出)。

代码语言:javascript
复制
/*Do once so compilation and caching out the way*/
EXEC('select st.text, qp.query_plan, cp.cacheobjtype, cp.objtype, cp.plan_handle
from sys.dm_exec_cached_plans cp 
cross apply sys.dm_exec_sql_text(cp.plan_handle) st
cross apply sys.dm_exec_query_plan(cp.plan_handle) qp')

DBCC TRACEON(1200,3604,-1);

SET TRANSACTION ISOLATION LEVEL READ COMMITTED
PRINT 'READ COMMITTED'
EXEC('select st.text, qp.query_plan, cp.cacheobjtype, cp.objtype, cp.plan_handle
from sys.dm_exec_cached_plans cp 
cross apply sys.dm_exec_sql_text(cp.plan_handle) st
cross apply sys.dm_exec_query_plan(cp.plan_handle) qp')


SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED
PRINT 'READ UNCOMMITTED'
EXEC('select st.text, qp.query_plan, cp.cacheobjtype, cp.objtype, cp.plan_handle
from sys.dm_exec_cached_plans cp 
cross apply sys.dm_exec_sql_text(cp.plan_handle) st
cross apply sys.dm_exec_query_plan(cp.plan_handle) qp')

DBCC TRACEOFF(1200,3604,-1);
票数 9
EN
页面原文内容由Database Administration提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://dba.stackexchange.com/questions/33074

复制
相关文章

相似问题

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