SpringBoot Mybatis批量插入Oracle數(shù)據(jù)庫數(shù)據(jù)
前端數(shù)據(jù)
有如下需求,前端提交一個對象cabinData,保存到數(shù)據(jù)表中,對象結構如下:
?{ ? ? ?"shipId":"424", ? ? ?"shipName":"大唐2號", ? ? ?"ballastCabinData":["艏尖艙","雙層底1左","雙層底1右","雙層底2左","雙層底2右","雙層底3左","雙層底3右","雙層底4左","雙層底4右","雙層底5左","雙層底5右","頂邊5左","頂邊5右","尾尖艙"], ? ? ?"freshCabinData":["淡水艙1左","淡水艙1右"] ?}
數(shù)據(jù)表結構
數(shù)據(jù)表是oracle,表結構為:
后端Controller:
?@PostMapping("/savecabin") ?public AjaxResult savecabin(@RequestBody Map<String,Object> postCabinData){ ?? ? ? ?// 獲取map中的參數(shù) ? ? ?String shipIdStr = (String) postCabinData.get("shipId"); ? ? ?Integer shipId = Integer.valueOf(shipIdStr); ? ? ?String shipName = (String) postCabinData.get("shipName"); ? ? ?List<String> ballastCabinData = (List<String>) postCabinData.get("ballastCabinData"); ? ? ?List<String> freshCabinData = (List<String>) postCabinData.get("freshCabinData"); ?? ? ? ?// 獲取shipid下的所有的船艙記錄 ? ? ?List<DraftCabin> list = draftCabinService.selectCabinByShipId(shipId); ? ? ?// 船艙記錄大于0時,執(zhí)行批量刪除;船艙 ? ? ?if (list.size()>0){ ? ? ? ? ?List<Long> idcards= list.stream().map(DraftCabin::getCabinId).collect(Collectors.toList()); ? ? ? ? ?Long[] ids = idcards.toArray(new Long[idcards.size()]); ? ? ? ? ?draftCabinService.deleteDraftCabinByIds(ids); ? ? } ? ? ?// 批量插入船艙 ? ? ?draftCabinService.insertDraftCabins(ballastCabinData,shipId,"壓艙水",shipName); ? ? ?draftCabinService.insertDraftCabins(freshCabinData,shipId,"淡水",shipName); ?? ? ? ?return AjaxResult.success(); ?}
解析:
- 使用
Map<String,Object>
來接收前端cabinData的JSON對象:使用map.get("shipId")方法來解析JSON獲得對應的值。 - 批量刪除時,使用list.stream().map(DraftCabin::getCabinId).collect(Collectors.toList())方法,使用類中的getCabinId方法來將結果集中的cabbinId形成數(shù)組參數(shù),入?yún)⑴縿h除方法
deleteDraftCabinByIds
- 批量插入時,調(diào)用service的insertDraftCabins方法,傳入四個參數(shù)(ballastCabinData,shipId,"壓艙水",shipName)
mapper
?public int insertDraftCabins(@Param("DraftCabin")List DraftCabin, @Param("shipId")Integer shipId, @Param("cabinType")String cabinType,@Param("shipName")String shipName) ;
解析:
mapper中,多個參數(shù)使用@Param注解來接收,在mybaits的xml中,調(diào)用注解名稱。
xml
?<!--批量新增--> ?<insert id="insertDraftCabins" useGeneratedKeys="false"> ? ? INSERT ALL ? ? ?<foreach collection="DraftCabin" item="item" index="index"> ? ? ? ? INTO draft_cabin ? ? ? ? (cabin_name,ship_id,cabin_type,ship_name) ? ? ? ? values(#{item},#{shipId},#{cabinType},#{shipName,jdbcType=VARCHAR}) ? ? ?</foreach> ? ? SELECT 1 FROM DUAL ?</insert>
解析:
- 批量新增
insertDraftCabins
,接收多個參數(shù),這時不要添加parameterType屬性,useGeneratedKeys="false",一定要添加; - foreach的collection是要遍歷的對象,這里填寫mapper中的注解名稱;
orcale的批量插入方法與mysql有很大區(qū)別,這里需要注意以下:
?insert all ? ? ?into <tableName>[(<table_column1>,<table_column2>...)] ? ? ?values([<column_value1>,<column_value2>...]) ? [into <tableName>[(<table_column1>,<table_column2>...)] ? values([<column_value1>,<column_value2>...])]... ?select ?<table_value1>[,<table_value2>...] from dual;
到此這篇關于SpringBoot Mybatis批量插入Oracle數(shù)據(jù)庫數(shù)據(jù)的文章就介紹到這了,更多相關SpringBoot 批量插入Oracle 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
spring @Scheduled注解的使用誤區(qū)及解決
這篇文章主要介紹了spring @Scheduled注解的使用誤區(qū)及解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-11-11在Java中如何決定使用 HashMap 還是 TreeMap
這篇文章主要介紹了在Java中如何決定使用 HashMap 還是 TreeMap,很多朋友對這樣的問題很迷茫,下面小編給大家?guī)硪黄恼聨椭蠹伊私?,需要的朋友可以參考?/div> 2019-10-10Spring Cloud 優(yōu)雅下線以及灰度發(fā)布實現(xiàn)
這篇文章主要介紹了Spring Cloud 優(yōu)雅下線以及灰度發(fā)布實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-11-11Java Hutool 包工具類推薦 ExcelUtil詳解
這篇文章主要介紹了Java Hutool 包工具類推薦 ExcelUtil詳解,需要引入hutool包,版本號可根據(jù)實際情況更換,除hutool包之外,還需要引入操作Excel必要包,本文給大家介紹的非常詳細,需要的朋友可以參考下2022-09-09nodejs連接dubbo服務的java工程實現(xiàn)示例
這篇文章主要介紹了在項目遷移中,nodejs連接dubbo服務的java工程實現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步2022-03-03最新評論