Springboot使用事务不生效

今天想要写一个批量插入用户的demo,既然是批量插入,必然会有一些预料不到的事情,所以需要使用事务来确保数据库数据安全,一旦有一条数据插入失败则所有的数据都不能被成功插入。

1.错误使用:
//在service层
@Transactional
    public Map<String, Object> batchAddUser(List<Map<String, Object>> dataMapList) {
        ......
        
        if(userList.size()>0){
	        try{
	        	success = saveBatch(userList);
	        }catch(Exception e){
	        	System.out.println(e);
			}
        }
        ......
    }

最后发现事务没有起作用,除了错误的数据都插入成功了。最后发现在service层中不能使用try catch捕获异常,@Transactional在抛出异常时进行回滚,但是try catch已经把异常捕获了,@Transactional没办法获取异常,也不知道在哪发生的异常,所以失效了。对代码进行修改,如下:

2. 正确使用
//controller层
try {
            result = userService.batchAddUser(dataMapList);
        }catch (Exception e){
            System.out.println(e);
            return BaseResult.error("500", "数据保存失败");
        }
//service
@Transactional
    public Map<String, Object> batchAddUser(List<Map<String, Object>> dataMapList) {
        ......
        if(userList.size()>0){
	    	success = saveBatch(userList);
        }
        ......
    }
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值