项目用到hibernate进行与mysql数据库的连接和操作,有一个“查询”模块和“添加”模块,是用不同的hibernate配置文件来做的。在做完添加后做查询时发现了问题,查询的结果总是添加之前的,而最新更新的记录却没有被查询得到。只有重启tomcat服务器才能查到更新的记录。
google之。
网上提到了hibernate的缓存机制,http://blog.csdn.net/fjun0910/article/details/6092829
按其中所说,查询前用session.clear();清除一级缓存,重新尝试添加+查询,还是查不到更新记录。用setCacheMode(CacheMode.IGNORE)清二级缓存,实验,失败。两个都进行清除,依然失败。
正迷茫时,找到了这里:http://blog.sina.com.cn/s/blog_6d818993010137in.html
虽然说得并不是很明白,但是找到了问题所在:hibernate默认连接池的问题,使用c3p0连接池就可以了。于是按此方法以下述步骤解决问题:
首先添加需要的jar包:hibernate-c3p0-4.2.0.final.jar,c3p0-0.9.2.1.jar,mchange-commons-java-0.2.7.jar,可以分布去http://mvnrepository.com/和 http://www.java2s.com/下载,注意mchange-commons-java的版本不要过低,否则会ClassNotFound错。
修改hibernate配置文件,用c3p0连接池连接数据库,在之前的配置以外加入如下配置:
<property name="hibernate.connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</property> <property name="hibernate.c3p0.max_size">20</property> <property name="hibernate.c3p0.min_size">5</property> <!-- <property name="hibernate.c3p0.timeout">120</property>--> <property name="automaticTestTable">Test</property> <property name="hibernate.c3p0.max_statements">100</property> <property name="hibernate.c3p0.idle_test_period">120</property> <property name="hibernate.c3p0.acquire_increment">1</property> <property name="c3p0.testConnectionOnCheckout">true</property> <property name="c3p0.idleConnectionTestPeriod">18000</property> <property name="c3p0.maxIdleTime">25000</property>
解决问题。
以上。
本文出自 “木木在路上” 博客,请务必保留此出处http://mumufairy.blog.51cto.com/6184508/1551220