使用TransactionScope()和NHibernate的BeginTransaction()问题

时间:2011-06-08 10:31:21

标签: mysql nhibernate transactionscope

我正在使用NHibernate 3.1.0和MySql Connector 6.3.5。作为一般规则,我的存储库方法包含在NHibernate事务中。但是,调用存储库方法的服务或应用程序代码可能还需要事务范围 - 因此将NHibernate事务与.NET的TransactionScope混合在一起。模拟测试如下所示:

[Test]
public void CanPerformNestedSave()
{
    using (var tx = new TransactionScope())
    {
        var user = new AdminUser { Email = "user@test.com", Name = "Test User 1", Password = "123" };

        using (ISession session = OpenSession())
        {
            using (var tx = session.BeginTransaction())
            {
                entity.ModifiedAt = DateTime.Now;
                session.SaveOrUpdate(entity);
                tx.Commit();

                return entity;
            }
        }

        tx.Complete();
    }
}

测试失败,出现以下错误:

NHibernate.TransactionException:SQL异常开始失败   ----> System.InvalidOperationException:不支持嵌套事务。

我已经在网上搜索了这个场景的解决方案,希望StackOverflow上的社区可以提供帮助。

1 个答案:

答案 0 :(得分:1)

我发表了关于此here的博文。

在博客文章中,NServiceBus为处理程序创建外部TransactionScope,并在处理程序内使用Nhibernate会话和事务。