hibernate 4 里如何配置c3p0数据库连接池。
hibernate 4的官方文档里面提到hibernate 4可以使用c3p0连接池
看着hibernate和spring的RELEASE版出来很久了.心痒就想升级一下.结果问题真来的不少 …记录下来.
spring升到3.1倒是简单,删除旧包,加新包,然后配置的
接着还是改spring里的 hibernate (使用 annotation) bean 配置.
先是SessionFactory 的 org.springframework.orm.hibernate3.annotation.AnnotationSessionFactory
接着把 org.springframework.orm.hibernate3.HibernateTransactionMana
然后移除hibernateTemplate.这个很重要,spring 3.1不再支持hibernateTemplate了.不晓得什么原因…没深究
然后就是大面积的修改类了…
因为不再使用 hibernateTemplate,都要改成 sessionFactory.getCurrentSession()…
这个转变其实也不算难,唯一有些区别的是对 DetachedCriteria 的操作.
hibernateTemplate.findByCriteria (DetachedCriteria,first,max) 换成 DetachedCriteria.getExecutableCriteria(sessionFactory.getCurrentSession()).setFirstResult(first).setMaxResults(max).list()
直接使用 sessionFactory.getCurrentSession().createCriteria(XXX.class) 代替 DetachedCriteria 是最简单的了.
去看看 hibernate的官方帮助里面有很详细的说明,足以轻松替换掉 hibernateTemplate , 改完基本也就升级完成了.
MVC OpenSessionInViewFilter:
- <filter>
-
<filter-name>openSessionInViewFilter</filter-name> -
<filter-class>org.springframework.orm.hibernate4.support.OpenSessionInViewFilter</filter-class> -
<init-param> -
<param-name>singleSession</param-name> -
<param-value>true</param-value> -
</init-param> -
<init-param> -
<param-name>sessionFactoryBeanName</param-name> -
<param-value>mySessionFactory</param-value> -
</init-param> - </filter>
-
- <filter-mapping>
-
<filter-name>openSessionInViewFilter</filter-name> -
<url-pattern>/*</url-pattern> - </filter-mapping>
另有多个数据源的问题:
原来旧版本没有的问题…就是有2个数据源,原先定义的2个sessionFactory 都能正常使用,但是升级后,第二个出现 No Session found for current thread 的问题.
可以简单用下面的方法解决这个问题.保险的话还是用JTA 去实现比较好…
spring配置里定义2个 transactionManager,然后 tx:annotation-driven 默认会使用名为 transactionManager 的那个.
<bean id=”transactionManager”>
</bean>
<bean id=”transactionManager2″>
</bean>
<tx:annotation-driven transaction-manager=”transactionManager”/>
接着在类里用到第二个 sessionFactory 的方法上再加上
@Transactional
public void method1(){
}
@Transactional(value=”transactionManager2″)
public void method2(){
}
因为第二个数据源是只读,所以也就没去判断这个事务是否会正常回滚.理论上是不会回滚的…
附多数据源:
http://www.360doc.com/content/09/1222/17/18042_11742680.shtml
http://www.cnblogs.com/sky7034/archive/2011/08/11/2134411.html
http://blog.csdn.net/wangdonghua2261/article/details/3872975