其他分享
首页 > 其他分享> > 跟着黑马学SSM——Day5之Spring事务

跟着黑马学SSM——Day5之Spring事务

作者:互联网

Spring事务简介

案例:银行转账

需求:实现任意两个账户间转账操作

需求微缩:A账户减钱,B账户加钱

分析:

  1. 数据层提供基础操作,指定账户减钱(outMoney),指定账户加钱(inMoney)
  2. 业务层提供转账操作(tranfer),调用减钱与加钱的操作
  3. 提供2个账户和操作金额执行转账操作
  4. 基于Spring整合Mybatis环境搭建上述操作

结果分析:

  1. 程序正常执行时,账户金额A减B加,没有问题
  2. 程序出现异常后,转账失败,但是异常之前操作成功,异常之后操作失败,整体业务失败

步骤:

  1. 在业务接口上添加Spring事务管理

    public interface AccountService {
    
        @Transactional
        void transfer(String out,String in,Double money);
    }
    /*注意事项
    *Spring注解式事务开发通常添加在业务层接口中而不会添加到业务层实现类中,降低耦合
    *注解式事务开发可以添加到业务方法上便是当前方法开启事务,也可以添加到接口上表示当前接口所有方法开启事务
    */
    
  2. 设置事务管理器

    @Bean
    public PlatformTransactionManager platformTransactionManager(DataSource dataSource){
        DataSourceTransactionManager dataSourceTransactionManager = new DataSourceTransactionManager();
        dataSourceTransactionManager.setDataSource(dataSource);
        return dataSourceTransactionManager;
    }
    /*注意事项
    *事务管理器要根据实现技术进行选择
    *Mybatis框架使用的式JDBC事务
    */
    
  3. 开启注解式事务驱动

    @Configuration
    @ComponentScan("com.xhj")
    @PropertySource("classpath:jdbc.properties")
    @Import({JdbcConfig.class,MybatisConfig.class})
    @EnableTransactionManagement
    public class SpringConfig {
    }
    

Spring事务角色

事务相关配置

案例:转账业务追加日志

需求:实现任意两个账户间转账操作,并对每次转账操作在数据库进行留痕

需求微缩:A账户减钱,B账户加钱,数据库记录日志

分析:

  1. 基于转账操作案例添加日志模块,实现数据库中记录日志
  2. 业务层转账操作(transfer),调用减钱,加钱与记录日志功能

实现效果预期:无论转账成功与否,均进行转账操作的日志留痕

事务传播行为

  1. 在业务层接口上添加Spring事务,设置事务传播行为REQUIRES_NEW(需要新事务)

    @Transactional(propagation = Propagation.REQUIRES_NEW)
    public interface LogService {
        void log(String out,String in,Double money);
    }
    

标签:转账,事务,账户,Spring,Day5,SSM,操作,日志
来源: https://www.cnblogs.com/ltom/p/16664958.html