读取 DMV 时设置 READ UNCOMMITTED

Jam*_*olt 12 sql-server dmv

我见过几个人SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED在阅读系统 DMV 之前打电话。是否有任何理由这样做,假设您没有在同一事务中混合调用 DMV 和表?

Bre*_*zar 11

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

如果您查询 DMV,这有关系吗?不会。但迟早,您将使用您的 DMV 脚本之一并添加到 sys.databases 或 sys.tables 或其他一些系统对象的连接,以便获得有关您正在查看的内容的更多信息。如果你在那里没有读未提交,你可以被其他查询阻止,并阻止其他查询。我一再被它烧毁,所以每当我做任何诊断工作时,我都会默认使用 READ UNCOMMITTED 。

  • @MartinSmith花了一段时间,但我最终确实在博客中介绍了[许多元数据函数如何忽略隔离级别](http://blogs.sqlsentry.com/aaronbertrand/bad-habits-metadata-helper-functions/)。我尝试清理很多代码,但从那时起我开发的任何新代码都更喜欢连接,而不是像“OBJECT_ID()”、“SCHEMA_NAME()”等内置函数。 (2认同)

Mar*_*ith 7

我不认为这有什么区别。

如果我尝试以下操作并比较 winmerge 中两个隔离级别的锁定输出,它们将完全相同(甚至将其设置为SERIALIZABLE不会更改输出)。

/*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);
Run Code Online (Sandbox Code Playgroud)