在SQL Server的.net /实体框架中设置事务隔离级别

本文关键字:设置 事务 隔离级 框架 实体 Server SQL net | 更新日期: 2023-09-27 18:01:21

我正在尝试在。net/c#中为事务设置事务隔离级别。我使用以下代码来设置事务:

 using (var db = new DbContext("ConnectionString"))
 {
     using (var transaction = new TransactionScope(TransactionScopeOption.RequiresNew, 
             new TransactionOptions() { IsolationLevel = IsolationLevel.Snapshot }))
     {
         ...code here
         transaction.Complete();
     }
 }

使用SQL Server Profiler,会产生以下结果:

set quoted_identifier on
set arithabort off
set numeric_roundabort off
set ansi_warnings on
set ansi_padding on
set ansi_nulls on
set concat_null_yields_null on
set cursor_close_on_commit off
set implicit_transactions off
set language us_english
set dateformat mdy
set datefirst 7
set transaction isolation level read committed

当我特别请求"快照"时,为什么将隔离级别设置为"已提交读取"?

已为相关数据库开启快照隔离。

这个'read committed'正在被另一个长时间运行的事务阻塞。

在长时间运行的事务期间,在SQL Server Management Studio中运行以下代码可以正常工作,但是上面的代码被阻塞,因为隔离级别正在从我指定的隔离级别更改。

USE <database>;
GO
SET TRANSACTION ISOLATION LEVEL SNAPSHOT;
GO
BEGIN TRANSACTION;
GO
<SELECT STATEMENT>
GO
COMMIT TRANSACTION;
GO

为什么?

在SQL Server的.net /实体框架中设置事务隔离级别

new TransactionScope所做的就是设置Transaction.Current。这就是它的全部功能。现在,任何想要支持事务的人都可以查看该属性并进行登记。通常的DbConnection类在开放时就会被招募。显然,在此特定作用域下,您的代码不会打开连接。

System.Transactions没有对更改隔离级别的内置支持(这是一个遗憾的遗漏)。你需要自己做。