Spring中具有多个数据源的事务
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Spring中具有多个数据源的事务相关的知识,希望对你有一定的参考价值。
我有2个类用于处理JDBC和Sqlite。这些类使用抽象类来扩展:
package atm.implementations;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate;
import javax.sql.DataSource;
public abstract class AbstractDAO {
NamedParameterJdbcTemplate jdbcTemplate;
@Autowired
public void setDataSource(DataSource dataSource) {
this.jdbcTemplate = new NamedParameterJdbcTemplate(dataSource);
}
}
头等舱:
package atm.implementations;
import atm.dao.SQLiteDAO;
import atm.objects.Bank;
import org.springframework.jdbc.core.RowMapper;
import org.springframework.jdbc.core.namedparam.MapSqlParameterSource;
import org.springframework.stereotype.Component;
import org.springframework.transaction.annotation.Isolation;
import org.springframework.transaction.annotation.Propagation;
import org.springframework.transaction.annotation.Transactional;
import java.sql.ResultSet;
import java.sql.SQLException;
@Component("bankDAO")
public class BankDAO extends AbstractDAO implements SQLiteDAO<Bank> {
@Transactional(propagation = Propagation.REQUIRED, isolation = Isolation.SERIALIZABLE)
public void updateRecord(Bank object) {
String sqlUpdate = "update bank set account_value = :value where id = :id";
MapSqlParameterSource params = new MapSqlParameterSource();
params.addValue("value", object.getAccountValue());
params.addValue("id", object.getId());
jdbcTemplate.update(sqlUpdate, params);
}
}
第二个:
package atm.implementations;
import atm.dao.TranDAO;
import org.springframework.jdbc.core.namedparam.MapSqlParameterSource;
import org.springframework.stereotype.Component;
import org.springframework.transaction.annotation.Isolation;
import org.springframework.transaction.annotation.Propagation;
import org.springframework.transaction.annotation.Transactional;
@Component("transDAO")
public class TranDAOImpl extends AbstractDAO implements TranDAO {
@Transactional(propagation = Propagation.MANDATORY, isolation = Isolation.SERIALIZABLE)
public void insert(String desc) {
String sqlInsert = "insert into transactions_list (description) values (:descr)";
MapSqlParameterSource params = new MapSqlParameterSource();
params.addValue("descr", desc);
jdbcTemplate.update(sqlInsert, params);
}
}
这是context.xml:
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd">
<context:component-scan base-package="atm.*"/>
<aop:aspectj-autoproxy proxy-target-class="true"/>
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="username" value=""/>
<property name="password" value=""/>
<property name="url" value="jdbc:sqlite:atm.db"/>
<property name="driverClassName" value="org.sqlite.JDBC"/>
</bean>
<tx:annotation-driven proxy-target-class="true" transaction-manager="transactionManager" />
<bean id="transactionManager"
class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource" />
</bean>
</beans>
我需要在两个类Transactional中创建方法,但Datasource在每个类实例中都是不同的。现在我有错误 - 没有找到标记为传播'强制'的交易的现有交易。
第一类使用新帐户参数更新数据库,第二类仅在有关此事务的单独表中插入文本。如果事务失败,则第二类不应插入任何信息。
我真的不想加入一个类中的所有代码,我想保持它分开。
是否有任何方法可以为所有类使用ONE SINGLE数据源?
答案
TranDAOImpl#insert标有MANDATORY-Transaction-Propagation。这意味着,调用者必须具有活动事务。我怀疑你在调用这个方法时遇到异常?
所以调用者本身应该被“REQUIRED”或“REQUIRES_NEW”注释。我不认为您的问题与使用不同的数据源有关。如果Spring连线正确完成,事务管理器应该以安全的方式处理它。
以上是关于Spring中具有多个数据源的事务的主要内容,如果未能解决你的问题,请参考以下文章