默认情况下,hibernate在会话期间发出查询之前刷新(FlushMode.AUTO),并消耗大量CPU时间。如果您有一个会话,其中许多查询和更新交替运行,那将特别痛苦。
如果查询可能选择回退在当前会话期间插入/更新/删除的数据,则需要进行这些刷新。这 可能
也是即使您没有修改在当前事务中任何东西,但使用的事务隔离级别一样读未提交的情况。
假设您不希望进行未提交的读取等,我知道有两种解决方法:
- 在进行 任何修改 之前, 请选择会话期间需要的所有内容(例如,重新排序,以便在进行任何修改之前发出所有查询)。
- 如果您确定要选择在此会话中未修改的数据,则可以将刷新模式显式设置为不会触发刷新的内容,如下所示:
Query query = session.getNamedQuery(SOME_QUERY_NAME);
query.setFlushMode(FlushMode.COMMIT);
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)