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

How to create single transaction manager for two oracle different datasources in jdbctemplate

我是新手 spring jdbc template.I 想为两个不同的对象创建一个事务管理器 datasources.Below 是我的配置详细信息

<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>

我尝试了上面的方法,但是在 database.Is 中没有发生回滚,这是实现事务的正确方法吗? 任何帮助将不胜感激!!!!

在这种情况下,您需要

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

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