Java spring boot 实现批量删除功能

简介: 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:

删除后的数据库:

完成!!!


相关文章
|
3天前
|
Java 数据安全/隐私保护 Spring
Java 中 Spring Boot 框架下的 Email 开发
Java 中 Spring Boot 框架下的 Email 开发
28 2
|
3天前
|
前端开发 Java 测试技术
Java一分钟之Spring MVC:构建Web应用
【5月更文挑战第15天】Spring MVC是Spring框架的Web应用模块,基于MVC模式实现业务、数据和UI解耦。常见问题包括:配置DispatcherServlet、Controller映射错误、视图解析未设置、Model数据传递遗漏、异常处理未配置、依赖注入缺失和忽视单元测试。解决这些问题可提升代码质量和应用性能。注意配置`web.xml`、`@RequestMapping`、`ViewResolver`、`Model`、`@ExceptionHandler`、`@Autowired`,并编写测试用例。
51 3
|
1天前
|
前端开发 JavaScript Java
Java网络商城项目 SpringBoot+SpringCloud+Vue 网络商城(SSM前后端分离项目)五(前端页面
Java网络商城项目 SpringBoot+SpringCloud+Vue 网络商城(SSM前后端分离项目)五(前端页面
Java网络商城项目 SpringBoot+SpringCloud+Vue 网络商城(SSM前后端分离项目)五(前端页面
|
1天前
|
Java 数据库连接 数据库
spring--为web(1),富士康java面试题整理
spring--为web(1),富士康java面试题整理
|
1天前
|
安全 Java 数据库
Spring boot 入门教程-Oauth2,java面试基础题核心
Spring boot 入门教程-Oauth2,java面试基础题核心
|
1天前
|
数据采集 监控 安全
java数字工厂MES系统全套源码Java+idea+springboot专业为企业提供智能制造MES解决方案
"MES" 指的是制造执行系统(Manufacturing Execution System)。MES在制造业中扮演着至关重要的角色,它是位于企业资源计划(ERP)系统和车间控制系统之间的系统,用于实时收集、管理、分析和报告与制造过程相关的数据。
8 0
|
3天前
|
Java 关系型数据库 MySQL
【Java Spring开源项目】新蜂(NeeBee)商城项目运行、分析、总结
【Java Spring开源项目】新蜂(NeeBee)商城项目运行、分析、总结
14 4
|
3天前
|
开发框架 监控 Java
深入探索Spring Boot的监控、管理和测试功能及实战应用
【5月更文挑战第14天】Spring Boot是一个快速开发框架,提供了一系列的功能模块,包括监控、管理和测试等。本文将深入探讨Spring Boot中监控、管理和测试功能的原理与应用,并提供实际应用场景的示例。
15 2
|
3天前
|
移动开发 前端开发 NoSQL
ruoyi-nbcio从spring2.7.18升级springboot到3.1.7,java从java8升级到17(二)
ruoyi-nbcio从spring2.7.18升级springboot到3.1.7,java从java8升级到17(二)
49 0
|
3天前
|
JSON 前端开发 Java
【JAVA进阶篇教学】第七篇:Spring中常用注解
【JAVA进阶篇教学】第七篇:Spring中常用注解