• spring 事务


    @component
    public class FooServiceImpl implements FooService{
        @Autowired
        private JdbcTemplate jdbcTemplate;
    
    
        @Override
        @Transactional
        public void insertRecord(){
            jdbcTempalte.eccute("INSERT INTO FOO (BAR) VALUES('AAA')");
        }
    
    
        @Overrive
        @Transactional(rollbackFor = RollbackException.calss)
        public void insertThenRollback(){
            jdbcTemplate.excute("INSERT INTO FOO (BAR) VALUES ('BBB')");
            throw new RollbackException();
        }
    
        @Overrive
        public void invokeInsertThenRollback() throws RollbackException{
            insertThenRollback();
        }
        //要想上面这个方法添加上事务
        第一步:注入实例
          @Autowired
        private FooService fooService;
        //把自己的实例注入进来,比较方便理解
        @Override
        public void invokeInsertThenRollbackBySelfService() throws RollbackException {
            fooService.insertThenRollback();
        }
        //获取当前代理,这样写避免了自己调用自己的实例
        @Override
        public void invokeInsertThenRollbackByAopContext() throws RollbackException {
            ((FooService) (AopContext.currentProxy())).insertThenRollback();
        }
        //再加一层事务
        @Transactional(rollbackFor = RollbackException.class)
        @Override
        public void invokeInsertThenRollbackAddTransactional() throws RollbackException {
            insertThenRollback();
        }
    
    }
    
    
    
    Public class DeclarativeTransactionDemApplication implements CommandLineRunner{
        @Autowried
        private FooService fooService;
        @Autowried
        private JdbcTemplate jdbcTemplate;
    
        public static void main (String[] args){
            SpringApplication.run(DeclarativeTransactionDemApplication.class);
        }
    
        @Override
        public void run(String... args){
            fooSerive.insertRecord();
    
            log.info("AAA {}",jdbcTemplate.queryForObject("SELECT COUNT(*) FROM FOO WHERE BAR ='AAA'",Long.class));
    
            //结果 1
    
            try{
                fooService.insertThenRollback();
            }catch(Exception e){
                log.info("BBB {}",jdbcTemplate.queryForObject("SELECT COUNT(*) FROM FOO WHERE BAR ='BBB'",Long.class));
            }
    
            //结果 0
    
            try{
                fooService.invokeInsertThenRollback();
            }catch(Exception e){
                log.info("BBB {}",jdbcTemplate.queryForObject("SELECT COUNT(*) FROM FOO WHERE BAR ='BBB'",Long.class));
            }
    
            //结果 1   spring 事务是通过穿建 代理对象来添加事务 这个是内部调用 调用方法  所以在调用的时候不会增强事务
            //要想它加上事务
    
    
        }
        
    }
  • 相关阅读:
    SecureCRT安装
    wmv12下安装centos7
    SpringMVC(十二):SpringMVC 处理输出模型数据之@ModelAttribute
    oracle之 redo过高诊断
    oracle之 手动创建 emp 表 与 dept 表
    oracle之 11.2.0.4 bbed安装
    oracle12c之 控制pdb中sga 与 pga 内存使用
    storm之 Storm 工作原理
    spark之 spark 2.2.0 Standalone安装、wordCount演示
    hadoop之 参数调优
  • 原文地址:https://www.cnblogs.com/panda777/p/11129259.html
Copyright © 2020-2023  润新知