Spring事务声明方式

事务(Transaction)是访问并可能更新数据库中各种数据项的一个程序执行单元(unit)

特性:原子性、一致性、隔离性、持久性

原子性(atomicity)。一个事务是一个不可分割的工作单位,事务中包括的诸操作要么都做,要么都不做。
一致性(consistency)。事务必须是使数据库从一个一致性状态变到另一个一致性状态。一致性与原子性是密切相关的。
隔离性(isolation)。一个事务的执行不能被其他事务干扰。即一个事务内部的操作及使用的数据对并发的其他事务是隔离的,并发执行的各个事务之间不能互相干扰。
持久性(durability)。持续性也称永久性(permanence),指一个事务一旦提交,它对数据库中数据的改变就应该是永久性的。接下来的其他操作或故障不应该对其有任何影响。

声明方式

必须先声明事务管理

 <!--事务配置开始-->
    <bean id="transactionManager"
          class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
       <!-- 数据源 -->
        <property name="dataSource" ref="dataSource"/>
    </bean>

声明使用模版:

<!--事务模版-->
    <bean id="transactionTemplate" class="org.springframework.transaction.support.TransactionTemplate">
        <property name="transactionManager" ref="transactionManager"/>
    </bean>

0.编程式声明事务,每次都要手动增加与实现其事务模版(不经常使用)

实现TransactionTemplate

public class AccountServiceImpl implements AccountService{

    private AccountDAO accountDAO;

    public void setAccountDAO(AccountDAO accountDAO) {
        this.accountDAO= accountDAO;
    } 
   

    private TransactionTemplate transactionTemplate;

    public void setTransactionTemplate(TransactionTemplate transactionTemplate) {
        this.transactionTemplate = transactionTemplate;
    }

    public void updateAccount(final int id, final  int toId,final double money){
        transactionTemplate.execute(new TransactionCallbackWithoutResult() {
            @Override
            protected void doInTransactionWithoutResult(TransactionStatus transactionStatus) {
                  // 编写处理逻辑代码
            }
        });
    }
}

 XML配置

<bean id="accountService" class="com.xx.service.AccountService">
   <!-- 对应声明实现的DAO -->
  <property name="accountDAO" ref="accountDAO"/> 
   <!-- 事务模版 -->
   <property name="transactionTemplate" ref="transactionTemplate"/> 
</bean>

1.基本方式(TransactionProxyFactoryBean声明方式,不常用,需要经常手动改动与编码)

<bean id="baseTransactionProxy" class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean"
     abstract="true">
<!-- 事务管理源 -->
   <property name="transactionManager" ref="transactionManager"/>
<!-- 事务属性,对应是执行方法, -->
   <property name="transactionAttributes">
     <props>
       <prop key="insert*">PROPAGATION_REQUIRED</prop>
       <prop key="update*">PROPAGATION_REQUIRED</prop>
       <prop key="*">PROPAGATION_REQUIRED,readOnly</prop>
     </props>
   </property>
 </bean>
<!-- 指向具体的类 -->
 <bean id="myProxy" parent="baseTransactionProxy">
   <property name="target" ref="指向的类名称(Service类)"/>
 </bean>
<!-- 指向具体的类 -->
 <bean id="yourProxy" parent="baseTransactionProxy">
   <property name="target" ref="指向的类名称(Service类)"/>
 </bean>

2.通知方式(基于AspectJ的XML方式,经常使用,一旦配置好了,不需要做改动)

 <!-- 事务通知 -->
    <tx:advice id="txAdvice"  transaction-manager="transactionManager">
        <tx:attributes>
            <!-- 设定方法的事务及事务属性 
                 propagation    事务传播
                 isolation      事务隔离级别
                 read-only     只读
                 rollback-for  发生哪些异常回滚
                 no-rollback-for   发生哪些异常不回滚
                 timeout        过期信息
            -->
            <tx:method name="save*" propagation="REQUIRED" isolation="DEFAULT"/>
            <tx:method name="update*" propagation="REQUIRED"/>
        </tx:attributes>
    </tx:advice>
    <!-- 配置切面-->
    <aop:config>
          <!--切入点 指向对应service包 -->
          <aop:pointcut id="prodou1" expression="execution(* com.yod.DAO.*(..))" ></aop:pointcut>
        <!-- 切入面-->
         <aop:advisor advice-ref="txAdvice" pointcut-ref="prodou1"/>
    </aop:config>

3.注解方式(经常使用,只要在类上增加 @Transactional的注解就可以了)

<!-- 以 @Transactional 标注来定义事务 -->
    <tx:annotation-driven transaction-manager="transactionManager" proxy-target-class="true"/>

对应类(Service)增加 @Transactional标识

@Transactional
public class MenusService extends BaseManager<MenusObj, Integer> {
 

}

 

转载于:https://my.oschina.net/u/2251646/blog/1509952

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值