事务

第一种配置方法:基于XML的事务管理

这种方法不需要对原有的业务做任何修改,通过在XML文件中定义需要拦截方法的匹配即可完成配置,要求是,业务处理中的方法的命名要有规律,比如setXxx,xxxUpdate等等。详细配置如下:

<!-- 定义事务处理类,不同的数据访问方式,事务处理类不同  
    比如:Hibernate操作的HibernateTransactionManager,JDBC操作的使用DataSourceTransactionManager  
 -->  
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">  
    <property name="dataSource" ref="dataSource"></property>  
</bean>  
  
<!-- 定义事务通知 -->  
<tx:advice id="txAdvice" transaction-manager="transactionManager">  
    <!-- 定义方法的过滤规则 -->  
    <tx:attributes>  
        <!-- 所有方法都使用事务 -->  
        <tx:method name="*" propagation="REQUIRED"/>  
        <!-- 定义所有get开头的方法都是只读的 -->  
        <tx:method name="get*" read-only="true"/>  
    </tx:attributes>  
</tx:advice>  
  
<!-- 定义AOP配置 -->  
<aop:config>  
    <!-- 定义一个切入点 -->  
    <aop:pointcut expression="execution (* com.iflysse.school.services.impl.*.*(..))" id="services"/>  
    <!-- 对切入点和事务的通知,进行适配 -->  
    <aop:advisor advice-ref="txAdvice" pointcut-ref="services"/>  
</aop:config>  

第二中配置方法:基于@Transactional的事务管理

这种方法,只需要在Spring配置文件中定义一个事务管理对象(如DataSourceTransactionManager),然后加入<tx:annotation-driven/>节点,引用该事务管理对象,然后即可在需要进行事务处理的方法使用@Transactional进行标注。示例如下:

Spring配置XML文件

<!-- 定义事务处理类,不同的数据访问方式,事务处理类不同  
    比如:Hibernate操作的HibernateTransactionManager,JDBC操作的使用DataSourceTransactionManager  
 -->  
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">  
    <property name="dataSource" ref="dataSource"></property>  
</bean>  
<!-- 声明使用注解式事务 -->  
<tx:annotation-driven transaction-manager="transactionManager"/>  

Java代码中@Transactional示例

/** 
 * @author ZYWANG 2011-3-24 
 */  
@Service  
@Transactional(propagation = Propagation.REQUIRED)  
public class TeacherServicesImpl implements TeacherServices {  
    @Autowired  
    TeacherDao dao = null;  
  
    public TeacherDao getDao() {  
        return dao;  
    }  
  
    public void setDao(TeacherDao dao) {  
        this.dao = dao;  
    }  
  
    @Override  
    @Transactional(readOnly=true,propagation=Propagation.NEVER)  
    public List<Teacher> getAllTeachers() {  
        return getDao().getAllTeachers();  
    }  
  
    @Override  
    public void addTeacher(Teacher teacher) {  
        if(teacher.getId() > 0){  
            getDao().updateTeacher(teacher);  
        }else{  
            getDao().addTeacher(teacher);  
        }  
    }  
}  

spring3.2+hibernate4.1采用声明式的事务处理

<?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:aop="http://www.springframework.org/schema/aop"  
    xmlns:tx="http://www.springframework.org/schema/tx" xmlns:context="http://www.springframework.org/schema/context"  
    xsi:schemaLocation="  
    http://www.springframework.org/schema/beans   
    http://www.springframework.org/schema/beans/spring-beans-2.5.xsd  
    http://www.springframework.org/schema/tx  
    http://www.springframework.org/schema/tx/spring-tx-2.5.xsd  
    http://www.springframework.org/schema/aop   
    http://www.springframework.org/schema/aop/spring-aop-2.5.xsd  
    http://www.springframework.org/schema/context     
    http://www.springframework.org/schema/context/spring-context-2.5.xsd  
 ">  
   
   
  <!-- 采用的annotation的方式进行AOP和 IOC -->  
      
    <!-- 配置了component-scan可以移除 -->  
     <context:annotation-config />   
    <!-- 启动对@AspectJ注解的支持 -->  
    <aop:aspectj-autoproxy />   
    <!-- 自动扫描包(自动注入) -->  
    <context:component-scan base-package="yingjun" />   
   
 <!-- 配置数据源 -->  
 <bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">  
  <property name="locations" value="classpath:jdbc.properties"/>  
</bean>  
   
 <bean id="DataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">  
   <property name="driverClassName" value="${jdbc.driverClassName}"/>  
   <property name="url" value="${jdbc.url}"/>  
   <property name="username" value="${jdbc.username}"/>  
   <property name="password" value="${jdbc.password}"/>  
 </bean>  
   
<!-- Hibernate配置 -->  
  <bean id="SessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean" >  
    <property name="dataSource" ref="DataSource"/>  
    <property name="packagesToScan">  
      <list>  
        <value>yingjun.model</value>  
      </list>  
    </property>  
    <property name="hibernateProperties">  
      <value>  
        hibernate.dialect=org.hibernate.dialect.MySQLDialect  
        hibernate.show_sql=true  
      </value>  
    </property>  
  </bean>  
   
  
     
 <bean id="txManager" class="org.springframework.orm.hibernate4.HibernateTransactionManager">  
    <property name="sessionFactory" ref="SessionFactory"/>  
  </bean>  
  <!-- 声明试事务管理 -采用annotation方式-->  
 <tx:annotation-driven transaction-manager="txManager"/>  
   
  <!-- 声明式事务管理 -采用XML方式-->  
    <!--常见几张几种事务传播行为类型  
       PROPAGATION_REQUIRED 如果当前没有事务,就新建一个事务,如果已经存在一个事务中,加入到这个事务中。这是最常见的选择。  
       PROPAGATION_SUPPORTS 支持当前事务,如果当前没有事务,就以非事务方式执行。  
       PROPAGATION_MANDATORY 使用当前的事务,如果当前没有事务,就抛出异常。  
       PROPAGATION_REQUIRES_NEW 新建事务,如果当前存在事务,把当前事务挂起。  
    -->  
  
  <tx:advice id="txAdvice" transaction-manager="txManager">  
    <tx:attributes>  
      <tx:method name="DoAdd*" propagation="REQUIRED"/>  
       <tx:method name="someOtherBusinessMethod" propagation="REQUIRES_NEW"/>  
      <tx:method name="get*" propagation="SUPPORTS" read-only="true"/>  
    </tx:attributes>  
  </tx:advice>  
    
   <aop:config>  
    <aop:pointcut id="productServiceMethods"  
                expression="execution(* yingjun.service.*.*(..))"/>  
    <aop:advisor advice-ref="txAdvice" pointcut-ref="productServiceMethods"/>  
  </aop:config>  
</beans>  

package yingjun.service;  
  
  
import javax.annotation.Resource;  
  
import org.springframework.stereotype.Component;  
import org.springframework.transaction.annotation.Transactional;  
  
import yingjun.dao.LogDaoI;  
import yingjun.dao.UserDaoI;  
import yingjun.model.Log;  
import yingjun.model.User;  
  
  
@Component("userService")  
public class UserService {  
      
    private UserDaoI userdao;  
    private LogDaoI logdao;  
      
    //@Transactional()  
    public void DoAddUser(User user,Log log){  
        userdao.AddUser(user);  
        logdao.addLog(log);  
      
    }  
    public UserDaoI getUserdao() {  
        return userdao;  
    }  
      
    @Resource(name="userDao")  
    public void setUserdao(UserDaoI userdao) {  
        this.userdao = userdao;  
    }  
  
  
    public LogDaoI getLogdao() {  
        return logdao;  
    }  
  
    @Resource(name="logDao")  
    public void setLogdao(LogDaoI logdao) {  
        this.logdao = logdao;  
    }  
      
  
}  


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值