首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >与Server错误相关的快照隔离

与Server错误相关的快照隔离
EN

Stack Overflow用户
提问于 2016-09-21 23:20:02
回答 1查看 1.2K关注 0票数 3

我得到以下错误(使用Server 2012)。

快照隔离事务访问数据库“db1”失败,因为此数据库中不允许快照隔离。使用ALTER允许快照隔离。

这种情况与其他博客所暗示的不同。我正在从另一个数据库(db1) (...using同义词)查询数据库表(db2.table 1)。错误查询的简化版本如下。

代码语言:javascript
复制
select col1, col2 
from db1.tab1 t 
inner join db2.table1
where xyz = 'abc'

db1具有默认的隔离级别(读取提交),而db2的隔离级别设置为快照隔离。

上面的查询失败了100种情况中的5种,并带有上述错误信息。

该查询正在使用实体框架6和应用程序中其他类似查询的一部分执行。所有其他操作都依赖于db2。

欢迎任何建议。

注->我不能将db1的隔离级别设置为作为分辨率的快照隔离。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-09-28 22:11:54

答案

问题在于实体框架如何重新使用连接池中的连接。让我们以两个查询为例

  • query1 (将TrasactionScope设置为快照隔离的查询)
  • query2 (表示上面定义的跨数据库查询的查询)

当query1执行时,Entity设置连接( query1执行时)以使用快照隔离级别。在另一个查询显式地更改了trasaction范围或连接被回收之前,相同的隔离级别将保持在连接中。请参阅 MSDN文章。

在100个案例中,有5个使用相同的连接来执行query2,这导致运行query2的隔离级别=“快照”。由于db1未设置为使用快照隔离,因此收到了错误。

一件重要的事要记住。

  • 当实体框架重用连接池中的连接时,它不会重置连接对象的隔离级别。为了强制对上下文使用特定的隔离级别,您需要显式地设置它。

希望这能帮助人们处理类似EF相关的间歇性错误。

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

https://stackoverflow.com/questions/39627936

复制
相关文章

相似问题

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