Java 如何在jdbctemplate中为两个oracle不同的数据源创建单个事务管理器

Java 如何在jdbctemplate中为两个oracle不同的数据源创建单个事务管理器,java,spring,transactions,jdbctemplate,Java,Spring,Transactions,Jdbctemplate,我是SpringJDBC模板的新手。我想为两个不同的数据源创建一个事务管理器。下面是我的配置细节 <bean id="dataSource1" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> <property name="driverClassName"> <value>oracle.jdbc.driver.Ora

我是SpringJDBC模板的新手。我想为两个不同的数据源创建一个事务管理器。下面是我的配置细节

<bean id="dataSource1"
        class="org.springframework.jdbc.datasource.DriverManagerDataSource">
        <property name="driverClassName">
            <value>oracle.jdbc.driver.OracleDriver</value>
        </property>
        <property name="url">
            <value>jdbc racle:thin:@localhost:1527/Hardua</value>
        </property>
        <property name="username">
            <value>selva</value>
        </property>
        <property name="password">
            <value>selva</value>
        </property>
</bean>
<bean id="dataSource2"
        class="org.springframework.jdbc.datasource.DriverManagerDataSource">
        <property name="driverClassName">
            <value>oracle.jdbc.driver.OracleDriver</value>
        </property>
        <property name="url">
            <value>jdbc racle:thin:@localhost:1527/Jaise</value>
        </property>
        <property name="username">
            <value>selva</value>
        </property>
        <property name="password">
            <value>selva</value>
        </property>
</bean>


<bean id="transactionManager"
        class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="dataSource1"></property>
        <property name="dataSource" ref="dataSource2"></property>
</bean>

<bean id="jdbcTemplate1 class="org.springframework.jdbc.core.JdbcTemplate">
        <property name="dataSource" ref="dataSource1"></property>
</bean>
<bean id="jdbcTemplate2 class="org.springframework.jdbc.core.JdbcTemplate">
        <property name="dataSource" ref="dataSource2"></property>
</bean>

oracle.jdbc.driver.OracleDriver
jdbc racle:thin:@localhost:1527/Hardua
塞尔瓦
塞尔瓦
oracle.jdbc.driver.OracleDriver
jdbc racle:thin:@localhost:1527/Jaise
塞尔瓦
塞尔瓦
我尝试了上面的方法,但在数据库中没有回滚。这是实现事务的正确方法吗?
任何帮助都将不胜感激

在这种情况下,您需要

JTA Transaction Manager (Global transaction Manager- 2 phase commit).

您必须使用JTA实现,例如spring自己的
JtaTransactionManager
,而不是本地事务管理器
DatasourceTransactionManager

在这种情况下,您需要一个

JTA Transaction Manager (Global transaction Manager- 2 phase commit).

您必须使用JTA实现,例如spring自己的
JtaTransactionManager
,而不是
DatasourceTransactionManager
,后者是本地事务管理器。

您是否需要为包含两个数据源的单个操作使用单个tx?不,这不是正确的方法,我甚至很惊讶容器是以这种配置开始的。你是需要一个tx来执行一个包含两个数据源的操作,还是只使用一个数据源?不,这不是正确的方法,我甚至对容器以这种配置开始感到惊讶。