zoukankan      html  css  js  c++  java
  • springboot手动事务回滚

    亲测在使用@Transactional、@Transactional(rollbackFor = Exception.class)及catch异常之后 throw new RuntimeException();仍然不能解决线程中的事务回滚。下面使用线程所机制,进行整体的事务提交及事务回滚,代码如下:

    在springboot启动类上加  @EnableTransactionManagement  注解
    

      线程类中添加以下代码

        @Autowired
        private PlatformTransactionManager platformTransactionManager;
        @Autowired
        private TransactionDefinition transactionDefinition;
        private Lock lock = new ReentrantLock();
        // todo 业务处理方法 数据存储异常 手动进行回滚
        public void saveMsg(String message) throws Exception {
            lock.lock();
            TransactionStatus transaction = platformTransactionManager.getTransaction(transactionDefinition);
            try {
            	//todo 具体业务,对数据库的操作 start
            	test1Service.save(test1);
            	test2Service.save(test2);
            	//end
            	
                platformTransactionManager.commit(transaction);
            } catch (Exception e) {
                platformTransactionManager.rollback(transaction);
                e.printStackTrace();
            } finally {
                lock.unlock();
            }
        }
    

      注:如果无法用 @Autowired 程序启动进行对象创建,可以使用init静态注入,如果对象可以正常创建,下面代码可以忽略。

        @Autowired
        private static PlatformTransactionManager platformTransactionManager;
        @Autowired
        private static TransactionDefinition transactionDefinition;
    
        @Autowired
        public void init(PlatformTransactionManager platformTransactionManager,TransactionDefinition transactionDefinition
        ) {
            DriverAlfaServerHandler.platformTransactionManager = platformTransactionManager;
            DriverAlfaServerHandler.transactionDefinition = transactionDefinition;
        }
    

      此回滚方法亲测有效。

  • 相关阅读:
    python线程池ThreadPoolExecutor用法
    redis学习笔记
    selenium + chrome 被检测,反反爬小记
    RabbitMQ单机快速安装使用
    NFS配置使用
    通过Rsync实现文件远程备份
    MySQL笔记-高可用方案
    Redis主从同步、哨兵模式、集群模式配置
    Redis维护笔记
    MongoDB笔记03——分片集群
  • 原文地址:https://www.cnblogs.com/lxyuuuuu/p/13363279.html
Copyright © 2011-2022 走看看