我有一个简单的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进行刷新吗?
如果没有,我该怎么做才能使其更快?
默认情况下,hibernate在会话期间发出查询之前刷新(FlushMode.AUTO),并消耗大量CPU时间。如果您有一个会话,其中许多查询和更新交替运行,那将特别痛苦。
如果查询可能选择回退在当前会话期间插入/更新/删除的数据,则需要进行这些刷新。这 可能 也是即使您没有修改在当前事务中任何东西,但使用的事务隔离级别一样读未提交的情况。
假设您不希望进行未提交的读取等,我知道有两种解决方法:
Query query = session.getNamedQuery(SOME_QUERY_NAME);
query.setFlushMode(FlushMode.COMMIT);