Java spring boot实现批量删除功能详细示例
前言
根据前面的删除的功能的实现,现在我们来实现一个可以批量删除的功能,不懂删除功能的可以跳到主页去搜索Java删除的功能即可,这里就不多进行啰嗦,那么进入正题!
原理:
批量删除的原理是通过一个循环来遍历要删除的用户信息的ID数组,然后依次调用单个删除矿工信息的方法来删除每一个用户信息。在删除的过程中,统计成功删除的信息数量、失败删除的信息数量以及失败原因,并最终返回给调用者。
在实际操作中,批量删除通常比单个删除效率更高,因为批量删除只需要一次连接数据库就可以删除多条数据,而单个删除则需要多次连接数据库。另外,批量删除还可以减少数据库的负担,因为在一次连接数据库的过程中,可以同时删除多条数据,而不需要多次连接数据库。
比较一下:
单个删除的Controller:
@CrossOrigin
@GetMapping("/miner/deleteUser")
public ResultResponse deleteMiner (@RequestParam Integer id) {
boolean result = userService.deleteUser(id);
if(result) {
return ResultResponse.returnToken(ResultResponse.success("删除信息成功"));
} else {
return ResultResponse.returnToken(ResultResponse.fail("删除信息失败"));
}
}通过GET请求,接收一个名为id的参数,用于删除单个用户的信息。方法体内调用了userService.deleteMiner方法,将id作为参数传递给业务层,如果删除成功则返回成功的响应,否则返回失败的响应。
批量删除的Controller:
@CrossOrigin
@PostMapping("/deleteBatchUser")
public ResultResponse deleteBatchuser(@RequestBody Integer[] ids) {
int successCount = 0; // 成功的信息
int failureCount = 0; // 失败的信息
List<String> failureReasons = new ArrayList<>();
for (Integer id : ids) {
boolean result = userService.deleteUser(id);
if (result) {
successCount++;
} else {
failureCount++;
failureReasons.add(String.format("删除用户信息 %d 失败", id));
}
}
// 判断批量删除成功和失败的操作程序
if (failureCount == 0) {
return ResultResponse.returnToken(ResultResponse.success(String.format("成功删除 %d 条用户信息", successCount)));
} else {
String failReason = "未知错误";
if (failureReasons.contains("数据库连接断开或不稳定,导致无法执行删除操作")) {
failReason = "数据库连接问题";
}
// 返回成功删除部分信息以及失败的部分和原因参数
return ResultResponse.returnToken(ResultResponse.fail(String.format("成功删除 %d 条用户信息 失败删除 %d 条信息,失败原因:%s",successCount, failureCount,failReason)));
}
}postman测试:

删除前的数据库:

SEND:

删除后的数据库:

完成!!!
总结
到此这篇关于Java spring boot实现批量删除功能的文章就介绍到这了,更多相关Java spring boot批量删除功能内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
解决java.lang.NoClassDefFoundError错误的问题
在Java开发过程中,NoClassDefFoundError是一个常见的运行时错误,是由于JVM在运行时找不到已编译的类文件导致的,本文就来介绍一下如何解决,具有一定的参考价值,感兴趣的可以了解一下2024-09-09
解决IDEA启动springboot项目报错java.lang.ClassNotFoundException: jav
这篇文章主要介绍了解决IDEA启动springboot项目报错java.lang.ClassNotFoundException: javax.servlet.ServletContext问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教2024-01-01
使用 Java 将 byte[] 转换为 File 对象并上
本文展示了如何通过 Java 和 Spring 来处理图像文件的获取、保存和上传,通过 RestTemplate 获取字节数组并将其转换为 File 对象,可以轻松实现从远程 URL 获取文件并将其上传到外部服务器,感兴趣的朋友一起看看吧2025-03-03
详解SpringBoot 多线程处理任务 无法@Autowired注入bean问题解决
这篇文章主要介绍了详解SpringBoot 多线程处理任务 无法@Autowired注入bean问题解决,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧2019-06-06


最新评论