Java 如何在jdbctemplate中为两个oracle不同的数据源创建单个事务管理器
我是SpringJDBC模板的新手。我想为两个不同的数据源创建一个事务管理器。下面是我的配置细节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
<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来执行一个包含两个数据源的操作,还是只使用一个数据源?不,这不是正确的方法,我甚至对容器以这种配置开始感到惊讶。