spring3 transaction

1. JBOSS中数据源的配置(mysql-xa-ds.xml支持分布式的事务),如下:

<datasources>

<xa-datasource>

<jndi-name>test1</jndi-name>

<track-connection-by-tx>true</track-connection-by-tx>

<xa-datasource-class>com.mysql.jdbc.jdbc2.optional.MysqlXADataSource</xa-datasource-class>

<xa-datasource-property name="Url">jdbc:mysql://10.0.0.107:3306/test1?useUnicode=true&characterEncoding=UTF-8</xa-datasource-property>

<xa-datasource-property name="User">root</xa-datasource-property>

<xa-datasource-property name="Password">root</xa-datasource-property>

<metadata>

<type-mapping>mySQL</type-mapping>

</metadata>

</xa-datasource>

<xa-datasource>

<jndi-name>test2</jndi-name>

<track-connection-by-tx>true</track-connection-by-tx>

<xa-datasource-class>com.mysql.jdbc.jdbc2.optional.MysqlXADataSource</xa-datasource-class>

<xa-datasource-property name="Url">jdbc:mysql://10.0.0.106:3306/test?useUnicode=true&characterEncoding=UTF-8</xa-datasource-property>

<xa-datasource-property name="User">root</xa-datasource-property>

<xa-datasource-property name="Password">root</xa-datasource-property>

<metadata>

<type-mapping>mySQL</type-mapping>

</metadata>

</xa-datasource>

</datasources>


2. Spring application-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"

xmlns:jee="http://www.springframework.org/schema/jee"

xsi:schemaLocation="http://www.springframework.org/schema/beans

http://www.springframework.org/schema/beans/spring-beans-3.0.xsd

http://www.springframework.org/schema/context

http://www.springframework.org/schema/context/spring-context-3.0.xsd

http://www.springframework.org/schema/aop

http://www.springframework.org/schema/aop/spring-aop-3.0.xsd

http://www.springframework.org/schema/tx

http://www.springframework.org/schema/tx/spring-tx-3.0.xsd

http://www.springframework.org/schema/jee http://www.springframework.org/schema/jee/spring-jee-3.0.xsd">

<context:component-scan base-package="com.youyu" />

<jee:jndi-lookup id="dataSource_first" jndi-name="java:test1" />

<jee:jndi-lookup id="dataSource_second" jndi-name="java:test2" />

<bean id="transactionManager"

class="org.springframework.transaction.jta.JtaTransactionManager">

<property name="userTransactionName">

<value>java:comp/UserTransaction</value>

</property>

</bean>

<bean id="sqlSessionFactory_first" class="org.mybatis.spring.SqlSessionFactoryBean">

<property name="dataSource" ref="dataSource_first" />

<property name="configLocation" value="classpath:batisConfig_first.xml" />

</bean>

<bean id="sqlSessionFactory_second" class="org.mybatis.spring.SqlSessionFactoryBean">

<property name="dataSource" ref="dataSource_second" />

<property name="configLocation" value="classpath:batisConfig_second.xml" />

</bean>

<bean id="mapperScannerConfigure_first" class="org.mybatis.spring.mapper.MapperScannerConfigurer">

<property name="basePackage" value="com.youyu.access" />

<property name="sqlSessionFactory" ref="sqlSessionFactory_first" />

</bean>

<bean id="mapperScannerConfigure_second" class="org.mybatis.spring.mapper.MapperScannerConfigurer">

<property name="basePackage" value="com.youyu.accesstwo" />

<property name="sqlSessionFactory" ref="sqlSessionFactory_second" />

</bean>

<tx:annotation-driven transaction-manager="transactionManager" />

</beans>


3. Service的注解,如下:

public interface AccountService {

@Transactional(readOnly=false,propagation=Propagation.REQUIRED)

public abstract int signUp(String name, String email);

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值