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

问题解决了。。。。
原来使用了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 文件
修复了 分页查询中数据量过大时内存溢出的问题。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值