业务层的事务控制

1.事务怎么控制的?

sqlsession.commit()  sqlsession.roolback()
connection.commit()  connection.roolback()

2.控制事务的关键对象是谁?

  connection

3.怎么从业务层获取到连接对象?

 将连接池对象注入到service实现类中,从而获取到连接对象 

4.代码冗余

由于将连接池注入到service之后,手动控制增删改的事务 出现了大量的
代码冗余 解决该问题可以使用面向切面编程

5.编码示例

MyTransactionAdvice  implments  MethodInterceptor{
private  DruidDatasource datasource;

 public void setDataSource(DruidDataSource dataSource) {
    this.dataSource = dataSource;
}

 public Object invoke(MethodInvocation methodInvocation){
 Connection conn=datasource.getConnection();
     try{
     conn.setAutoCommit(false);
     //目标方法
     methodInvocation.proceed();
     conn.commit()
     }catch(Exception e){
      conn.roolback()
     }
 }

}

6. //将通知对象交由工厂管理

  <bean id="advice" class="MyTransactionAdvice">
		<property name="dataSource" ref="datasource"/>
  </bean>

  <aop:config>
     <aop:pointcut id=“pt” expression="excuction(* com.baihzi.service.*.*(..))"/>
     <aop:advisor pointcut-ref="pt" advice-ref="advice">
  </aop:config>

7.对于手动控制事务 会造成线程安全的问题?

 在spring中提供一个类 DataSourceTransactionManager(当前类
 可以保证service 和dao拿到的是同一个连接)

 //创建线程安全的DataSourceTransactionManager
<bean id="dataSourceTransactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
	<property name="datasource" ref="dataSource">
</bean>

//控制事务的通知类 依赖DataSourceTransactionManager
<tx:advice id="advice"  TransactionManager="dataSourceTransactionManager">
</tx:advice>

<aop:config>
 <aop:pointcut id=“pt” expression="excuction(* com.baihzi.service.*.*(..))"/>
 <aop:advisor pointcut-ref="pt" advice-ref="advice">
</aop:config>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值