c# - 是否有必要在交易中包装 nHibernate future ?

标签 c# .net nhibernate

是否有必要在交易中包装 nHibernate future ?

如:

using (var s = sf.OpenSession())
using (var tx = s.BeginTransaction())
{
    var blogs = s.CreateCriteria<Blog>()
        .SetMaxResults(30)
        .List<Blog>();
    var countOfBlogs = s.CreateCriteria<Blog>()
        .SetProjection(Projections.Count(Projections.Id()))
        .UniqueResult<int>();

    Console.WriteLine("Number of blogs: {0}", countOfBlogs);
    foreach (var blog in blogs)
    {
        Console.WriteLine(blog.Title);
    }

    tx.Commit();
}

从这里:

https://ayende.com/blog/3979/nhibernate-futures

我看不出这样做的理由。这是一个选择而不是插入或更新等。

最佳答案

当 NHibernate 查询未显式包装在事务中时,它被称为“隐式事务”,这是不鼓励的,并且具有各种含义,包括使二级缓存无效。这一切都在这里解释:

https://hibernatingrhinos.com/Products/nhprof/learn#DoNotUseImplicitTransactions

摘录:

Even if we are only reading data, we should use a transaction, because using transactions ensures that we get consistent results from the database. NHibernate assumes that all access to the database is done under a transaction, and strongly discourages any use of the session without a transaction.

关于c# - 是否有必要在交易中包装 nHibernate future ?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43097763/

相关文章:

linq - 如何实现与 EF 和 NHibernate 一起使用的工作单元

c# - 机器人框架禁用用户输入框

c# - Send Message 和 Post Message 之间有什么区别,它们与 C#、WPF 和纯 Windows 编程有什么关系?

c# - Linq查询合并2个列表

c# - 数据变化发生在单位转换中

mysql - 工作单元的副作用可以用 TransactionScope 修复,但它不适用于 MySql.Data

c# - 如何在WPF应用程序中保存图片

.net - XAML 解析异常

c# - 如何使用C#属性?

c# - 流利的 nHibernate 不返回数据