如何在EF for MSSQL中获得隔离级别?

问题描述 投票:0回答:1

我使用EF来帮助LINQ访问MS SQL数据。如何获得当前的隔离级别?例如这段代码:

var level = 
Database.Connection.UnderlyingTransaction.IsolationLevel.ToString();

给我错误 - System.NullReferenceException: Object reference not set to an instance of an object.

据我所知 - UnderlyingTransaction为null因为我在LINQ代码中没有使用任何事务。

c# sql-server linq isolation-level
1个回答
0
投票

我找不到如何使用EF属性或方法获取当前隔离级别,因此我们可以使用自定义SQL查询,例如:

public class UserOptionsMsSql
{
    [Column("Set Option")]
    public string SetOption { get; set; }

    public string Value { get; set; }
}

var resultsList = 
service.GetDataContext().Database.SqlQuery<UserOptionsMsSql>
("DBCC USEROPTIONS;").ToList();

var resultLevel =  resultsList[11] == null ? "unknown":resultsList[11].Value ;

当然我们可以使用任何other custom SQL scripts ......

© www.soinside.com 2019 - 2024. All rights reserved.