• 简单解决你的事务回滚问题


    /**
         * 用户登录接口
         * 
         * 
         * 1明确事务方法前的命名规则
         * 2保证事务方法执行的时间尽可能的短,不允许出现循环操作,不允许出现RPC等网络请求操作
         * 3不允许所有的方法都使用事务,节省服务器性能和缩短数据库连接时间
         * 4如果出现有多个地方需要事务回滚时,使用自定义或原有的异常进行抛出,异常必须继承RunTimeError,否则不会触发回滚操作
         * 5使用TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();进行手动回滚
         * 
         */
        @Transactional
        public UserModel login(UserModel user){
            
            UserModel userEntity = new UserModel();
            
            
            userEntity = userDao.login(user);
            if(userEntity == null)
            {
                return null;
            }
            
            userEntity = userDao.login(user);
            if(userEntity == null)
            {
                TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
                return null;
            }
            else
            {
                return userEntity;
            }
        }

    直接给出一个例子代码,上面只是记录一下,下面才是干货。

    首先很多时候我们不会采用事务操作,但是当我们在一个服务层多次访问数据库特别是进行插入删除操作的时候,我们需要使用事务进行操作,也就是一个不成功,所有的操作全部回滚。

    那么具体的事务特性我就不多说了,规范我也打在最上面的注释里面了。主要注意一下,

    使用@Transactional 注解

    如果第一次插入成功,第二次插入失败,执行TransactionAspectSupport.currentTransactionStatus().setRollbackOnly(); 这条语句之后,第一次的插入动作就被回滚了,也就是并没有生效。

    手动回滚看起来会比较实用一些。

    然后对于抛出异常的那种自动回滚可以参考百度各种代码。比较麻烦一些,就不列举了。

    补充一下:

    使用Object savePoint = TransactionAspectSupport.currentTransactionStatus().createSavepoint(); 
    设置回滚点,使用TransactionAspectSupport.currentTransactionStatus().rollbackToSavepoint(savePoint);回滚到savePoint。
     
     
    后序补充详细属性配置(复杂)
  • 相关阅读:
    poj3468一个简单的整数问题,我昨天一下午才写好的水代码。
    【虚幻】虚幻引擎小技巧
    ubuntu添加并设置屏幕分辨率
    ECDH秘钥协商算法原理
    ECC椭圆曲线算法2
    Neighbor Discovery Protocol
    IPv6 linklocal 地址的功能和原理
    ECC椭圆曲线算法3
    Linux下使用可视化的串口调试工具cutecom
    AES五种加密模式(CBC、ECB、CTR、OCF、CFB)
  • 原文地址:https://www.cnblogs.com/linkstar/p/5671951.html
Copyright © 2020-2023  润新知