【发布时间】:2013-02-27 02:10:58
【问题描述】:
我在尝试使用 LinqToSql 添加行时收到InvalidOperationException。我们不能在内部复制它,而且只有我们的一个客户发生了大约 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() 完成的数据库更新实际上正在发生。事务成功完成后将调用此异常,并将数据库行更新为新值。
【问题讨论】:
-
这是否只发生在特定的代码块上,如果是这样,它是否在任何时候都在
using块内? -
我们所有的数据库更新函数都调用一个通用函数来执行 DataContext SubmitChanges()。所以总是同一行代码失败。
标签: c# linq sql-server-2008 datacontext