我有使用JPA和JDBC的混合應用。我已經使用@Transactional註釋成功完成了JPA事務的設置,但是我無法使它適用於JDBC。問題而設置的彈簧基於註解的交易
我的配置是這樣的:
<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}"/>
<property name="testOnBorrow" value="true"/>
<property name="testOnReturn" value="true"/>
<property name="testWhileIdle" value="true"/>
<property name="timeBetweenEvictionRunsMillis" value="1800000"/>
<property name="numTestsPerEvictionRun" value="3"/>
<property name="minEvictableIdleTimeMillis" value="1800000"/>
</bean>
<bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager" >
<property name="entityManagerFactory" ref="entityManagerFactory"/>
</bean>
<tx:annotation-driven transaction-manager="transactionManager"/>
<bean class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean" id="entityManagerFactory">
<property name="persistenceUnitName" value="persistenceUnit"/>
<property name="dataSource" ref="dataSource"/>
</bean>
<bean class="org.springframework.jdbc.core.JdbcTemplate" id="jdbcTemplate">
<property name="dataSource" ref="dataSource"/>
</bean>
我的代碼是:
@Test
@Transactional
public void testUpdateSQLwithParam() {
Object[] params = { "John","", "trol", "test", "M", "Place", "123456789",
"[email protected]" };
customQueryDao.insert("PERSON_INSERT_QUERY", params);
String sqlConstant = "PERSON_MASTER_UPADTE_QUERY";
params = new Object[]{ "Test", 8 };
customQueryDao.updateSQLwithParam(sqlConstant, params);
}
我的JDBC代碼使用的JdbcTemplate執行查詢。請讓我知道如何使用@Transactional註解來實現JDBC事務。使用jpatransactionmgr
我使用jdbc模板,如果JpaTransactionManager也支持這一點,我已經嘗試過但不工作 – 2014-10-10 05:57:53
@ PrashantShah它應該工作...如果有錯誤,你能顯示堆棧跟蹤,還是描述會發生什麼? – 2014-10-10 06:16:29
你好嗶嘰,感謝您的回覆,我在下面的測試被插入行和更新其他行,其中第二個查詢所賜例外仍然在第一行得到表中插入代碼 – 2014-10-10 09:18:20