0

我在 wcf 应用程序中遇到升级分布式事务的问题。

我的代码看起来像这样:

日志存储库

    public void AddLog(ImportLogDbo log)
    {
        using (DbManager dbManager = new DbManager("controlServerConnectionString"))
        {
            dbManager.SetSpCommand("dbo.ImportLog_Create",
                                   dbManager.Parameter("@ImportFile", log.ImportFile),
                                   dbManager.Parameter("@ImportError", log.ImportError),
                                   dbManager.Parameter("@ImportHash", log.ImportHash),
                                   dbManager.Parameter("@ImportCompleted", log.ImportCompleted))
             .ExecuteNonQuery();
        }
    }

日志服务

    public void AddImportLog(string ImportFile, string ImportHash)
    {
        ImportLogDbo importLogDbo = new ImportLogDbo
        {
            ImportCompleted = false,
            ImportFile = ImportFile,
            ImportHash = ImportHash                
        };


        if (_importLogRepository.GetByFileName(ImportFile) == null)
        {
            using (TransactionScope scope = new TransactionScope())
            {
                _importLogRepository.AddLog(importLogDbo);
                scope.Complete();
            }
        }

    }

项目在 .NET 4 中,我使用 Sql Server 2008R2

上面的代码调用我的 wcf 服务,它是这样配置的

  <wsHttpBinding>
    <binding name="wsHttpBinding" transactionFlow="True" maxReceivedMessageSize="2147483647" closeTimeout="5:00:00" openTimeout="5:00:00" receiveTimeout="5:00:00" />          
  </wsHttpBinding>

<endpoint address="http://localhost:8080/AppServer/WsDocumentImportService" binding="wsHttpBinding" name="wsBinding" contract="ComDocs.AppServerServiceLibary.Abstract.IDocumentImportService"/>

我的问题是在事务范围内,它总是以分布式方式推广。

我做错了什么?(我对 wcf 服务编程有点陌生)

谢谢

4

1 回答 1

0

transactionFlow = “true” 会将事务传播到服务边界之外。尝试将其设置为 false。您需要一个更细粒度的事务范围,您可以使用该属性对其进行设置。有关更多信息,请查看以下内容:

http://msdn.microsoft.com/en-us/magazine/cc163432.aspx

于 2011-08-24T14:23:23.877 回答