如何在 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
,后者是本地事务管理器。
我是新手 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
,后者是本地事务管理器。