1

我正在尝试使用实体框架 4 实现事务。根据我的阅读,下面的代码是正确的。SaveChanges 工作正常,但只要我点击第一个 ExecuteFunction 调用,我就会得到以下异常:

基础提供程序在打开时失败。---> System.Transactions.TransactionManagerCommunicationException:分布式事务管理器 (MSDTC) 的网络访问已被禁用。请使用组件服务管理工具在 MSDTC 的安全配置中启用 DTC 以进行网络访问。

我已登录到数据库服务器,但没有看到名为 Distributed Transaction Manager 的服务,但确实看到了 Distributed Transaction Coordinator 并且它已启动。我不确定我需要进行哪些更改才能使其正常工作。有人知道吗?谢谢。

这是代码。

using (var h = new WhaleEntities(ConnectionHelper.DBConnectString))
{
    using (TransactionScope ts = new TransactionScope())
    {
        h.Sites.AddObject(s);
        h.SaveChanges(SaveOptions.DetectChangesBeforeSave); 
        retval = s.SiteID;

        h.ExecuteFunction("UpdateSiteInterfaceList", new ObjectParameter("pSiteID", retval), new ObjectParameter("pList", "10"));
        h.ExecuteFunction("UpdateSiteInterfaceRequiredList", new ObjectParameter("pSiteID", retval),new ObjectParameter("pList", "Email"));
        h.ExecuteFunction("UpdateSiteInterfaceAlwaysShownList", new ObjectParameter("pSiteID", retval),new ObjectParameter("pList", "10"));
        h.ExecuteFunction("UpdateSiteInterfaceAlwaysRequiredList",new ObjectParameter("pSiteID", retval),new ObjectParameter("pList", "Email"));

        ts.Complete();

        //changes must be accepted manually once transaction succeeds.
        h.AcceptAllChanges();
    }
}
4

1 回答 1

1

请参阅此处:如何在 SQL Server 上启用 MSDTC?

于 2010-09-29T13:12:55.267 回答