我想为 c3p0 设置 testConnectionOnCheckin 属性。
但是我在这样做时遇到了麻烦,因为 c3p0 数据源是在休眠实体管理器 bean 中代表我创建的。
<bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
<property name="persistenceUnitManager" ref="persistenceUnitManager" />
<property name="persistenceProviderClass" value="org.hibernate.ejb.HibernatePersistence" />
<property name="jpaProperties">
<props>
<prop key="hibernate.dialect">${taxeng.entityManagerFactory.dialect}</prop>
<prop key="hibernate.hbm2ddl.auto">${taxeng.entityManagerFactory.ddl}</prop>
<prop key="hibernate.cache.provider_class">${taxeng.entityManagerFactory.cache}</prop>
<!-- Note that we use this due to the "ClassNotFoundException: org.hibernate.hql.ast.HqlToken" issue -->
<prop key="hibernate.query.factory_class">org.hibernate.hql.classic.ClassicQueryTranslatorFactory</prop>
<!-- Database connection pooling -->
<prop key="hibernate.c3p0.min_size">${taxeng.hibernate.c3p0.min_size}</prop>
<prop key="hibernate.c3p0.max_size">${taxeng.hibernate.c3p0.max_size}</prop>
<prop key="hibernate.c3p0.timeout">${taxeng.hibernate.c3p0.timeout}</prop>
<prop key="hibernate.c3p0.acquire_increment">${taxeng.hibernate.c3p0.acquire_increment}</prop>
<prop key="hibernate.c3p0.idle_test_period">${taxeng.hibernate.c3p0.idle_test_period}</prop>
<prop key="hibernate.c3p0.max_statements">${taxeng.hibernate.c3p0.max_statements}</prop>
<prop key="hibernate.show_sql">false</prop>
</props>
</property>
其中每个<prop key...1
> 是一个休眠配置键,休眠用它代表我创建一个 c3p0 数据源。
但是,我找不到将设置 c3p0 数据源的 testConnectionsOnCheckin 属性的休眠配置键。
有这样的钥匙吗?如果没有,那么我应该直接设置 entityManagers 数据源吗?在这样做之前我应该知道什么技巧吗?
注意: testConnectionsOnCheckout 不是一个可行的选项,它有一个对应的休眠配置键。