Java?spring?boot實(shí)現(xiàn)批量刪除功能詳細(xì)示例
前言
根據(jù)前面的刪除的功能的實(shí)現(xiàn),現(xiàn)在我們來實(shí)現(xiàn)一個可以批量刪除的功能,不懂刪除功能的可以跳到主頁去搜索Java刪除的功能即可,這里就不多進(jìn)行啰嗦,那么進(jìn)入正題!
原理:
批量刪除的原理是通過一個循環(huán)來遍歷要刪除的用戶信息的ID數(shù)組,然后依次調(diào)用單個刪除礦工信息的方法來刪除每一個用戶信息。在刪除的過程中,統(tǒng)計(jì)成功刪除的信息數(shù)量、失敗刪除的信息數(shù)量以及失敗原因,并最終返回給調(diào)用者。
在實(shí)際操作中,批量刪除通常比單個刪除效率更高,因?yàn)榕縿h除只需要一次連接數(shù)據(jù)庫就可以刪除多條數(shù)據(jù),而單個刪除則需要多次連接數(shù)據(jù)庫。另外,批量刪除還可以減少數(shù)據(jù)庫的負(fù)擔(dān),因?yàn)樵谝淮芜B接數(shù)據(jù)庫的過程中,可以同時刪除多條數(shù)據(jù),而不需要多次連接數(shù)據(jù)庫。
比較一下:
單個刪除的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的參數(shù),用于刪除單個用戶的信息。方法體內(nèi)調(diào)用了userService.deleteMiner方法,將id作為參數(shù)傳遞給業(yè)務(wù)層,如果刪除成功則返回成功的響應(yīng),否則返回失敗的響應(yīng)。
批量刪除的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("數(shù)據(jù)庫連接斷開或不穩(wěn)定,導(dǎo)致無法執(zhí)行刪除操作")) { failReason = "數(shù)據(jù)庫連接問題"; } // 返回成功刪除部分信息以及失敗的部分和原因參數(shù) return ResultResponse.returnToken(ResultResponse.fail(String.format("成功刪除 %d 條用戶信息 失敗刪除 %d 條信息,失敗原因:%s",successCount, failureCount,failReason))); } }
postman測試:
刪除前的數(shù)據(jù)庫:
SEND:
刪除后的數(shù)據(jù)庫:
完成?。?!
總結(jié)
到此這篇關(guān)于Java spring boot實(shí)現(xiàn)批量刪除功能的文章就介紹到這了,更多相關(guān)Java spring boot批量刪除功能內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
解決java.lang.NoClassDefFoundError錯誤的問題
在Java開發(fā)過程中,NoClassDefFoundError是一個常見的運(yùn)行時錯誤,是由于JVM在運(yùn)行時找不到已編譯的類文件導(dǎo)致的,本文就來介紹一下如何解決,具有一定的參考價值,感興趣的可以了解一下2024-09-09解決IDEA啟動springboot項(xiàng)目報(bào)錯java.lang.ClassNotFoundException:?jav
這篇文章主要介紹了解決IDEA啟動springboot項(xiàng)目報(bào)錯java.lang.ClassNotFoundException:?javax.servlet.ServletContext問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-01-01spring Security的自定義用戶認(rèn)證過程詳解
這篇文章主要介紹了spring Security的自定義用戶認(rèn)證過程詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-09-09使用MyBatis攔截器實(shí)現(xiàn)SQL的完整打印
當(dāng)我們使用Mybatis結(jié)合Mybatis-plus進(jìn)行開發(fā)時,為了查看執(zhí)行sql的信息通常我們可以通過屬性配置的方式打印出執(zhí)行的sql語句,但這樣的打印出了sql語句常帶有占位符信息,不利于排錯,所以本文介紹了構(gòu)建MyBatis攔截器,實(shí)現(xiàn)SQL的完整打印,需要的朋友可以參考下2024-07-07Mybatis實(shí)戰(zhàn)之TypeHandler高級進(jìn)階
本文主要介紹了自定義的枚舉TypeHandler的相關(guān)知識,具有很好的參考價值,下面跟著小編一起來看下吧2017-02-02使用 Java 將 byte[] 轉(zhuǎn)換為 File 對象并上
本文展示了如何通過 Java 和 Spring 來處理圖像文件的獲取、保存和上傳,通過 RestTemplate 獲取字節(jié)數(shù)組并將其轉(zhuǎn)換為 File 對象,可以輕松實(shí)現(xiàn)從遠(yuǎn)程 URL 獲取文件并將其上傳到外部服務(wù)器,感興趣的朋友一起看看吧2025-03-03詳解SpringBoot 多線程處理任務(wù) 無法@Autowired注入bean問題解決
這篇文章主要介紹了詳解SpringBoot 多線程處理任務(wù) 無法@Autowired注入bean問題解決,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-06-06關(guān)于Spring源碼是如何解決Bean的循環(huán)依賴
這篇文章主要介紹了關(guān)于Spring源碼是如何解決Bean的循環(huán)依賴,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-12-12