Java spring boot实现批量删除功能详细示例

 更新时间:2023年08月18日 11:31:10   作者:丘比特惩罚陆  
这篇文章主要给大家介绍了关于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高并发的并发级别详解

    java高并发的并发级别详解

    这篇文章主要介绍了java高并发的并发级别,内容十分丰富,在这里分享给大家,需要的朋友可以参考,希望能够给你带来帮助
    2021-10-10
  • SpringCloud应用骨架开发详解

    SpringCloud应用骨架开发详解

    这篇文章主要介绍了SpringCloud应用骨架开发详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • 详解springboot中使用异步的常用两种方式及其比较

    详解springboot中使用异步的常用两种方式及其比较

    这篇文章主要介绍了详解springboot中使用异步的常用两种方式及其比较,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-01-01
  • Java的DelayQueue延迟队列简单使用代码实例

    Java的DelayQueue延迟队列简单使用代码实例

    这篇文章主要介绍了Java的DelayQueue延迟队列简单使用代码实例,DelayQueue是一个延迟队列,插入队列的数据只有达到设置的延迟时间时才能被取出,否则线程会被阻塞,插入队列的对象必须实现Delayed接口,需要的朋友可以参考下
    2023-12-12
  • FastJSON字段智能匹配踩坑的解决

    FastJSON字段智能匹配踩坑的解决

    这篇文章主要介绍了FastJSON字段智能匹配踩坑的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-06-06
  • Spring相关知识点的总结与梳理

    Spring相关知识点的总结与梳理

    今天小编就为大家分享一篇关于Spring相关知识点的总结与梳理,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-02-02
  • 详解Spring Bean的配置方式与实例化

    详解Spring Bean的配置方式与实例化

    本文主要带大家一起学习一下Spring Bean的配置方式与实例化,文中的示例代码讲解详细,对我们学习Spring有一定的帮助,需要的可以参考一下
    2022-06-06
  • Java贪吃蛇游戏完善版

    Java贪吃蛇游戏完善版

    这篇文章主要为大家详细介绍了Java贪吃蛇游戏完善版,支持菜单操作,键盘监听,可加速,减速,统计得分等功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-04-04
  • 详解SpringBoot读取resource目录下properties文件的常见方式

    详解SpringBoot读取resource目录下properties文件的常见方式

    这篇文章主要介绍了SpringBoot读取resource目录下properties文件的常见方式,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-02-02
  • java集合框架的体系结构详细说明

    java集合框架的体系结构详细说明

    最近在一本J2EE的书中看到了很不错的对集合框架的说明文章
    2012-11-11

最新评论