我使用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代码中没有使用任何事务。
我找不到如何使用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 ......