単一の dataSource があり、JPA プロバイダーとして Spring 3.0.3、Hibernate 3.5.1 を使用し、いくつかのクエリに MyBatis 3.0.2 を使用し、Tomcat 6 でアプリを実行します。両方を呼び出すと、HibernateDAO と MyBatisDAO があります。 @Transactional で注釈が付けられた同じメソッドから、同じトランザクションを共有していないように見え、異なる接続を取得します。
どうすれば彼らにやらせることができますか?
DataSourceUtils.getConnection(dataSource) から接続を取得しようとしましたが、MyBatis で使用されているものを取得しましたが、これは奇妙です。問題は MyBatis の構成にあり、JpaTransactionManager を使用できないと思いました。DataSoruceUtils.getConnection を複数回呼び出しても、常に同じ接続が得られますが、これで問題ありません。
いくつかのグーグル検索の後、私は spring-instrument-tomcat のクラスローダーを試しました (ただし、Tomcat が実際にそれを使用しているかどうかはわかりません:))
部分的な applicationContext
<bean class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close" id="dataSource">
<property name="driverClassName" value="${database.driverClassName}"/>
<property name="url" value="${database.url}"/>
<property name="username" value="${database.username}"/>
<property name="password" value="${database.password}"/>
</bean>
<bean class="org.springframework.orm.jpa.JpaTransactionManager" id="transactionManager">
<property name="entityManagerFactory" ref="entityManagerFactory"/>
</bean>
<tx:annotation-driven mode="aspectj" transaction-manager="transactionManager"/>
<bean class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean" id="entityManagerFactory">
<property name="dataSource" ref="dataSource"/>
</bean>
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource" />
<property name="configLocation" value="classpath:META-INF/mybatis/mybatis-config.xml" />
</bean>
部分的な mybatis 構成
<settings>
<setting name="cacheEnabled" value="false" />
<setting name="useGeneratedKeys" value="false" />
<setting name="defaultExecutorType" value="REUSE" />
<setting name="lazyLoadingEnabled" value="false"/>
</settings>
部分的な永続性.xml
<persistence-unit name="persistenceUnit" transaction-type="RESOURCE_LOCAL">
<provider>org.hibernate.ejb.HibernatePersistence</provider>