c# - Linq DataContext SubmitChanges InvalidOperationException from ZombieCheck

标签 c# linq sql-server-2008 datacontext

我收到了 InvalidOperationException尝试使用 LinqToSql 添加行时。我们无法在内部复制它,并且只有我们的一个客户发生了大约 0.06%,总是对数据库进行相对简单的更改。 (单行插入,或单字段更新)

Message:
   This SqlTransaction has completed; it is no longer usable.
Stack Trace:
   at System.Data.SqlClient.SqlTransaction.ZombieCheck()
   at System.Data.SqlClient.SqlTransaction.Rollback()
   at System.Data.Linq.DataContext.SubmitChanges(ConflictMode failureMode)

这是一段示例代码(数据库自动生成主键)
TableName row = new TableName();
row.Description = "something";
row.Action = "action";
Context.TableName.InsertOnSubmit(row);
Context.SubmitChanges();

我们使用 SQL Server 2008 R2。插入和更新确实在服务器上进行。但我们仍然得到异常。没有什么可以阻止这些更新和插入的发生。没有依赖项或其他东西。

我们如何阻止这些异常/僵尸检查/回滚的发生,或者首先是什么导致它们?

编辑:

经过进一步检查,SubmitChanges() 正在执行的数据库更新实际上正在发生。事务成功完成后将调用此异常,并将数据库行更新为新值。

最佳答案

需要注意的一件事是 LinqToSql(和 EntityFramework)默认会分配 nullDateTime数据对象中的字段,因此如果您的表有 datetime如果 datacontext 尝试插入该空值,它将在插入时抛出异常。

您可以使用 datetime2 解决此错误。输入 MSSQL(这将允许 DateTime 对象的“空”值 - 01/01/0001)或手动为数据对象的 DateTime 分配一个有效日期插入/更新之前的字段。

如果没有更详细的堆栈跟踪,这是唯一想到的明显问题。哈。

编辑:

看起来这并不少见:http://connect.microsoft.com/VisualStudio/feedback/details/588676/system-data-linq-datacontext-submitchanges-causes-invalidoperationexception-during-rollback#details

根本问题似乎是 LinqToSql 使用的内部 ADO 逻辑没有真正正确配置来处理事务回滚。据我所知,唯一真正的解决方案是向 LinqToSql 提供一个事务对象并自己管理回滚,这似乎并不那么吸引人。

关于c# - Linq DataContext SubmitChanges InvalidOperationException from ZombieCheck,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15346402/

相关文章:

c# - A* 寻路算法并不总能找到最短路线 C# XNA

sql-server-2008 - 奇怪的 SQL Server 比较总是错误的

java - 从SQL Server 2005升级到SQL Server 2008,JAVA应用程序会出现错误吗?

c# - 等待类方法完成 C#

c# - 从 WSDL 文件读取 minOccurs 和默认值

c# - 获取 map 的 View 边界

c# - 从 Linq 中的列表中选择多个字段

c# - Quicksort with Linq performance Advantage passing T[] 与 IEnumerable<T>

c# - LINQ with group_concat - 在一个字段中获取链接的表结果

sql - 状态更改之间的天数