一尘不染

如何防止Hibernate刷新列表?

hibernate

我有一个简单的hibernate查询,例如:

from MyEntity where name = ?

没什么花哨的,但是它在一个相当大的事务中被多次调用(持续一秒钟,可能会加载数十个或数百个实体)。Profiler显示很多时间花在:

org.hibernate.internal.SessionImpl.autoFlushIfRequired(SessionImpl.java:1185)
org.hibernate.internal.SessionImpl.list(SessionImpl.java:1240)
org.hibernate.internal.QueryImpl.list(QueryImpl.java:101)

换句话说-在运行实际查询之前刷新会更改。

我能以某种方式完全阻止Hibernate进行刷新吗?

如果没有,我该怎么做才能使其更快?


阅读 325

收藏
2020-06-20

共1个答案

一尘不染

默认情况下,hibernate在会话期间发出查询之前刷新(FlushMode.AUTO),并消耗大量CPU时间。如果您有一个会话,其中许多查询和更新交替运行,那将特别痛苦。

如果查询可能选择回退在当前会话期间插入/更新/删除的数据,则需要进行这些刷新。这 可能
也是即使您没有修改在当前事务中任何东西,但使用的事务隔离级别一样读未提交的情况。

假设您不希望进行未提交的读取等,我知道有两种解决方法:

  1. 在进行 任何修改 之前, 请选择会话期间需要的所有内容(例如,重新排序,以便在进行任何修改之前发出所有查询)。
  2. 如果您确定要选择在此会话中未修改的数据,则可以将刷新模式显式设置为不会触发刷新的内容,如下所示:
    Query query = session.getNamedQuery(SOME_QUERY_NAME);
    

    query.setFlushMode(FlushMode.COMMIT);

2020-06-20