首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在.NET / Entity Framework for SQL Server中设置事务隔离级别

在.NET / Entity Framework for SQL Server中设置事务隔离级别
EN

Stack Overflow用户
提问于 2015-07-08 00:09:25
回答 1查看 4.3K关注 0票数 3

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

代码语言:javascript
复制
 using (var db = new DbContext("ConnectionString"))
 {
     using (var transaction = new TransactionScope(TransactionScopeOption.RequiresNew, 
             new TransactionOptions() { IsolationLevel = IsolationLevel.Snapshot }))
     {
         ...code here

         transaction.Complete();
     }
 }

使用SQL Server事件探查器,这将生成以下内容:

代码语言:javascript
复制
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

当我特别请求'snapshot‘时,为什么它将隔离级别设置为'read committed’?

已为有问题的数据库打开快照隔离。

此“已提交读取”正被另一个长时间运行的事务阻塞。

在长时间运行的事务期间,在SQL Server Management Studio中运行以下代码可以很好地工作,但上面的代码会被阻塞,因为隔离级别与我指定的隔离级别不同。

代码语言:javascript
复制
USE <database>;
GO
SET TRANSACTION ISOLATION LEVEL SNAPSHOT;
GO
BEGIN TRANSACTION;
GO

<SELECT STATEMENT>

GO
COMMIT TRANSACTION;
GO

为什么?

EN

回答 1

Stack Overflow用户

发布于 2015-07-08 03:33:05

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

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

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

https://stackoverflow.com/questions/31273933

复制
相关文章

相似问题

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