mysql - 使用 TransactionScope() 与 NHibernate 的 BeginTransaction() 问题

标签 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 上的社区可以提供帮助。

最佳答案

我已经写了关于这个的博客 here .

在博文中,NServiceBus 为处理程序创建了外部 TransactionScope,并且在处理程序内部使用了 Nhibernate session 和事务。

关于mysql - 使用 TransactionScope() 与 NHibernate 的 BeginTransaction() 问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6277381/

相关文章:

sql - 分布式数据库解决方案?

javascript - 将 javascript Canvas 路径保存到数据库中的正确方法

nhibernate - 使用 NHibernate 按计数分组

c# - 将 PENDING 锁设置为 EF core Sqlite

php - 如何使用 PHP 查找特定时间段的总工作时间

android - openfire可以和mysql服务器合并吗

asp.net - 每个 session 的 NH 请求 - "Session is closed!"

nhibernate - 如何处理 API 中的多对多关系

transactions - 嵌套 ADO.NET 事务损坏的连接池(使用 MSDTC)