2

我有一个服务级别的方法,它对数据库进行很少的更改,我希望它们使用事务控制。此类方法可以执行以下操作: - LINQ SubmitChanges() 功能 - 调用 StoredProcedures

组件用户可以将一组这样的基本操作组合成更大的东西。

我看到有一个不错的类 TransactinScope 并尝试使用它:

using (TransactionScope transaction = new TransactionScope())
{
     content = repository.CreateBaseContent(content);
     result = repository.CreateTreeRelation(content, parent.Id, name);
     transaction.Complete();
}

public baseContent CreateBaseContent(baseContent content)
{
       EntityContext.baseContents.InsertOnSubmit(content);
       EntityContext.SubmitChanges();

       return content;
}

public CreateTreeRelation (params)
{
// do StoredProcedure call here via LINQ
}

我的假设是在外层可以添加另一个级别的事务范围。相反,我遇到以下错误:

事务管理器已禁用对远程/网络事务的支持。(来自 HRESULT 的异常:0x8004D024)

我正在为 MS SQL 2005 和微软开发服务器使用相同的(Vista Ultimate)机器。从单元测试一切正常。TransactionScope 评论时相同。

我试图使用 DTC ( http://support.microsoft.com/kb/899191 ) 的安全性,当我设置接受所有入站和出站事务时,我收到以下错误消息:

对 COM 组件的调用已返回错误 HRESULT E_FAIL。

在调试过程中,我发现在 SubmitChanges 中,Linq Entity Context 有 Property Transaction IS NULL(!!),而 System.Transactions.Transaction.Current 有打开事务

4

2 回答 2

3

我认为您也可以使用 TransactionScope,只要您将数据上下文传递给您.Open 的相同连接。

TransactionScope 遇到的另一个问题是它不关心连接字符串是否相同,执行第二个 .Open 会将事务提升为分布式事务。然后你必须处理相关的配置,以及它没有使用这种情况所需的轻交易这一事实。

于 2009-04-12T13:37:00.993 回答
2

发生问题是因为 Linq Datacontext 是在 transactionscope 之前创建的。

解决方案是将自己的事务控制添加到 LINQ 数据上下文。

Connection.Open()
Transaction = Connection.BeginTransaction();

和计数器来维护嵌套调用。

于 2009-04-08T13:00:24.277 回答