• spring3.0事务管理配置


    转载:http://war-martin.iteye.com/blog/1396335

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

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

    Xml代码  收藏代码
    1. <!-- 定义事务处理类,不同的数据访问方式,事务处理类不同  
    2.     比如:Hibernate操作的HibernateTransactionManager,JDBC操作的使用DataSourceTransactionManager  
    3.  -->  
    4. <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">  
    5.     <property name="dataSource" ref="dataSource"></property>  
    6. </bean>  
    7.   
    8. <!-- 定义事务通知 -->  
    9. <tx:advice id="txAdvice" transaction-manager="transactionManager">  
    10.     <!-- 定义方法的过滤规则 -->  
    11.     <tx:attributes>  
    12.         <!-- 所有方法都使用事务 -->  
    13.         <tx:method name="*" propagation="REQUIRED"/>  
    14.         <!-- 定义所有get开头的方法都是只读的 -->  
    15.         <tx:method name="get*" read-only="true"/>  
    16.     </tx:attributes>  
    17. </tx:advice>  
    18.   
    19. <!-- 定义AOP配置 -->  
    20. <aop:config>  
    21.     <!-- 定义一个切入点 -->  
    22.     <aop:pointcut expression="execution (* com.iflysse.school.services.impl.*.*(..))" id="services"/>  
    23.     <!-- 对切入点和事务的通知,进行适配 -->  
    24.     <aop:advisor advice-ref="txAdvice" pointcut-ref="services"/>  
    25. </aop:config>  

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

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

    Spring配置XML文件

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

    Java代码中@Transactional示例

    Java代码  收藏代码
    1. /** 
    2.  * @author ZYWANG 2011-3-24 
    3.  */  
    4. @Service  
    5. @Transactional(propagation = Propagation.REQUIRED)  
    6. public class TeacherServicesImpl implements TeacherServices {  
    7.     @Autowired  
    8.     TeacherDao dao = null;  
    9.   
    10.     public TeacherDao getDao() {  
    11.         return dao;  
    12.     }  
    13.   
    14.     public void setDao(TeacherDao dao) {  
    15.         this.dao = dao;  
    16.     }  
    17.   
    18.     @Override  
    19.     @Transactional(readOnly=true,propagation=Propagation.NEVER)  
    20.     public List<Teacher> getAllTeachers() {  
    21.         return getDao().getAllTeachers();  
    22.     }  
    23.   
    24.     @Override  
    25.     public void addTeacher(Teacher teacher) {  
    26.         if(teacher.getId() > 0){  
    27.             getDao().updateTeacher(teacher);  
    28.         }else{  
    29.             getDao().addTeacher(teacher);  
    30.         }  
    31.     }  
    32. }  

     

     个人认为第一中方式的配置的侵入性低多了,写程序时只需要关注业务和命名规范,不需要考虑事务处理;第二种方式的配置可以更加灵活的使用事务,个性化定制。

     

    以上配置基于Spring 3.0.5 进行设置,参考其《Reference Documentation》

  • 相关阅读:
    POJ 2778(自动机+矩阵幂乘(字符串果然是个坑爹玩应!))
    CF357D(规律题,不好想出来!)
    HDU 4107(线段树 特殊懒惰标记)g++ TLE,c++才过(呜呜呜呜)
    hdu 3954(线段树的特殊lazy操作-更新时才遍历!)
    CF354C(思路+(左区间++,1+右区间--思想))
    hdu3851(dp+区间范围很大且有循环的处理方法)
    CF119D(字符串-哈希求解(KMP求了半天,结果哈希更简单!))
    CF 353D
    HDU 4760 字典树(题意比较难理解)
    hdu3649(取石子博弈+dp)
  • 原文地址:https://www.cnblogs.com/daodan/p/3926724.html
Copyright © 2020-2023  润新知