今天想要写一个批量插入用户的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);
}
......
}