@Transactional事务管理下独立出一个事务对数据库进行操作,防止事务回滚了不想要回滚的更改

情景:

        由于现在做的项目给前端的不正常提示都是通过抛出异常来返回的,抛出异常后会在拦截器中处理异常并将前端能看懂的提示返回给前端。

         最近有个需求是登录错误将数据库的连续登录错误次数加1,成功错误次数清零,那么在同一事务下正常操作数据库进行加1,那么在登录错误后抛出异常“登录错误”,事务会回滚,导致加1的操作没有更新到数据库。

         开始考虑利用多线程来操作,但是在操作较多的情况下数据容易错乱,所以想到“连续登录错误次数加1”这个更新操作利用原生jdbc进行数据库操作,然后手动控制jdbc的事务。

/**
 * 更新连续登录错误次数
 * 因为在事务里面,密码不正确会抛异常,所以如果使用普通的修改事务会回滚
 * 这里采用原生jdbc保存的方式,手动提交
 * @param userNo
 * @return
 */
@Override
public int updateErrNum(String userNo){
    DataSource dataSource = jdbcTemplate.getDataSource();
    Connection connection = DataSourceUtils.getConnection(dataSource);
    int result = 0;
    try {
        connection.setAutoCommit(false);//设置不自动提交
        PreparedStatement stat = null;
        String sql = "update xxxxxxxxxxxxx";
        stat = connection.prepareStatement(sql);
        stat.setString(1, userNo);
        result = stat.executeUpdate();
        connection.commit();//手动提交
        connection.setAutoCommit(true);//还原
    } catch (Exception e) {
        e.printStackTrace();
        try {//事务回滚
            connection.rollback();
            connection.setAutoCommit(true);
            connection.close();
        } catch (SQLException e1) {
            throw new ServiceException(e1.getMessage());
        }
        throw new ServiceException(e.getMessage());
    }
    return result;
}

这里连接池会自己回收connection,如果不自动回收的就自己关闭或者其他操作吧。

 

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Spring框架中,使用 @Transactional 注解可以控制事务的行为。其中,事务回滚可以通过设置 @Transactional 注解的 rollbackFor 或 noRollbackFor 属性来实现。rollbackFor 属性用于指定哪些异常触发事务回滚,而 noRollbackFor 属性用于指定哪些异常不触发事务回滚。这样,在方法执行过程中,如果抛了设置的异常类型,事务将会回滚。另外,@Transactional 注解还支持在方法上使用 rollbackOnly 属性来强制回滚事务。 需要注意的是,如果一个没有事务的方法调用了一个事务的方法,由于调用没有经过代理类,而是直接调用原始的 Bean,那么 @Transactional 注解将会失效,事务将无法回滚。因此,在使用 @Transactional 注解时,要注意方法之间的调用关系,确保事务能够正确地被应用和回滚。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [Spring 事务 -- @Transactional的使用](https://blog.csdn.net/wl1101780628/article/details/110120587)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [Spring中@Transactional事务回滚](https://blog.csdn.net/xiaojin21cen/article/details/83507174)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值