现在的位置: 首页 > 综合 > 正文

Hibernate 二级缓存 失效问题!!!

2013年01月01日 ⁄ 综合 ⁄ 共 820字 ⁄ 字号 评论关闭
问题解决了。。。。
原来使用了SQLQuery 然后执行了 executeUpdate();
就是executeUpdate会把所有的缓存都清除。。。
 ============
 而且一定要记住,要么在代码中使用 this.getHibernateTemplate().setCacheQueries(true);
要么就在配置文件中加上
<bean id="hibernateTemplate" class="org.springframework.orm.hibernate3.HibernateTemplate">
<property name="sessionFactory" ref="sessionFactory"></property>
<property name="cacheQueries" value="true"></property>
</bean>

很容易漏掉的东西 自己给自己提个醒

====================

有一个解决方案就是,直接修改源代码中的东西,把修改的那一行给注释掉。
修改原因:hibernate3 在 对sql 语句的excuteUpdate()调用时候,会清空相关实体的二级缓存,但是有些时候我们并不需要清空二级缓存,
所以注释掉 NativeSQLQueryPlan.java 中的 coordinateSharedCacheCleanup( session ),如果想要对sql 语句 的 executeUpdate() 同时清空相应实体的二级缓存
,可以手动调用getSessionFactory().evict(class1) 。

SybaseDialect.java,Sybase11Dialect.java

修改原因:hibernate 在针对sybase数据库分页查询的时候没有真正实现在数据库端的分页处理, 所以修改了Sybase11Dialect .java 和 SybaseDialect .java 文件

修复了 分页查询中数据量过大时内存溢出的问题。

抱歉!评论已关闭.