Query query = session.createQuery(hql);
// 绝大多数的查询并不能从查询缓存中受益,所以Hibernate在做了配置文件设置以后仍然默认不进行查询缓存的,
// 只有调用 Query.setCacheable(true)方法进行查询缓存。
// 这个调用会让查询在执行过程中时先从缓存中查找结果,并将自己的结果集放到缓存中去。
query.setCacheable(true);
// 如果要对查询缓存的失效政策进行精确的控制,必须调用Query.setCacheRegion()方法,
// 为每个查询指定自定义的查询缓存区域,若不设置,则使用标准查询缓存区域
// cachePageFront为自定义的缓存id名
query.setCacheRegion("cachePageFront");
// 如果查询需要强行刷新其查询缓存区域,那么应该调用Query.setCacheMode(CacheMode.REFRESH)方法。
// 这对在其他进程中修改底层数据(例如,不通过Hibernate修改数据),
// 或对那些需要选择性更新特定查询结果集的情况特别有用。
query.setCacheMode(CacheMode.REFRESH);