欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SpringBoot Mybatis批量插入Oracle數(shù)據(jù)庫(kù)數(shù)據(jù)

 更新時(shí)間:2022年08月25日 10:42:03   作者:沈麼鬼???????  
這篇文章主要介紹了SpringBoot Mybatis批量插入Oracle數(shù)據(jù)庫(kù)數(shù)據(jù),文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下

前端數(shù)據(jù)

有如下需求,前端提交一個(gè)對(duì)象cabinData,保存到數(shù)據(jù)表中,對(duì)象結(jié)構(gòu)如下:

?{
? ? ?"shipId":"424",
? ? ?"shipName":"大唐2號(hào)",
? ? ?"ballastCabinData":["艏尖艙","雙層底1左","雙層底1右","雙層底2左","雙層底2右","雙層底3左","雙層底3右","雙層底4左","雙層底4右","雙層底5左","雙層底5右","頂邊5左","頂邊5右","尾尖艙"],
? ? ?"freshCabinData":["淡水艙1左","淡水艙1右"]
?}

數(shù)據(jù)表結(jié)構(gòu)

數(shù)據(jù)表是oracle,表結(jié)構(gòu)為:

后端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時(shí),執(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> 來(lái)接收前端cabinData的JSON對(duì)象:使用map.get("shipId")方法來(lái)解析JSON獲得對(duì)應(yīng)的值。
  • 批量刪除時(shí),使用list.stream().map(DraftCabin::getCabinId).collect(Collectors.toList())方法,使用類中的getCabinId方法來(lái)將結(jié)果集中的cabbinId形成數(shù)組參數(shù),入?yún)⑴縿h除方法deleteDraftCabinByIds
  • 批量插入時(shí),調(diào)用service的insertDraftCabins方法,傳入四個(gè)參數(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中,多個(gè)參數(shù)使用@Param注解來(lái)接收,在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,接收多個(gè)參數(shù),這時(shí)不要添加parameterType屬性,useGeneratedKeys="false",一定要添加;
  • foreach的collection是要遍歷的對(duì)象,這里填寫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;

到此這篇關(guān)于SpringBoot Mybatis批量插入Oracle數(shù)據(jù)庫(kù)數(shù)據(jù)的文章就介紹到這了,更多相關(guān)SpringBoot 批量插入Oracle 內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解Java創(chuàng)建線程的五種常見(jiàn)方式

    詳解Java創(chuàng)建線程的五種常見(jiàn)方式

    Java中如何進(jìn)行多線程編程,如何使用多線程?不要擔(dān)心,本文將為你詳細(xì)介紹一下Java實(shí)現(xiàn)線程創(chuàng)建的五種常見(jiàn)方式,感興趣的可以跟隨小編學(xué)習(xí)一下
    2022-01-01
  • spring @Scheduled注解的使用誤區(qū)及解決

    spring @Scheduled注解的使用誤區(qū)及解決

    這篇文章主要介紹了spring @Scheduled注解的使用誤區(qū)及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-11-11
  • 在Java中如何決定使用 HashMap 還是 TreeMap

    在Java中如何決定使用 HashMap 還是 TreeMap

    這篇文章主要介紹了在Java中如何決定使用 HashMap 還是 TreeMap,很多朋友對(duì)這樣的問(wèn)題很迷茫,下面小編給大家?guī)?lái)一篇文章幫助大家了解,需要的朋友可以參考下
    2019-10-10
  • Java實(shí)現(xiàn)螺旋矩陣的示例

    Java實(shí)現(xiàn)螺旋矩陣的示例

    這篇文章主要介紹了Java實(shí)現(xiàn)螺旋矩陣的示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-02-02
  • Spring Cloud 優(yōu)雅下線以及灰度發(fā)布實(shí)現(xiàn)

    Spring Cloud 優(yōu)雅下線以及灰度發(fā)布實(shí)現(xiàn)

    這篇文章主要介紹了Spring Cloud 優(yōu)雅下線以及灰度發(fā)布實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • Java利用移位運(yùn)算將int型分解成四個(gè)byte型的方法

    Java利用移位運(yùn)算將int型分解成四個(gè)byte型的方法

    今天小編就為大家分享一篇關(guān)于Java利用移位運(yùn)算將int型分解成四個(gè)byte型的方法,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2018-12-12
  • Java Hutool 包工具類推薦 ExcelUtil詳解

    Java Hutool 包工具類推薦 ExcelUtil詳解

    這篇文章主要介紹了Java Hutool 包工具類推薦 ExcelUtil詳解,需要引入hutool包,版本號(hào)可根據(jù)實(shí)際情況更換,除hutool包之外,還需要引入操作Excel必要包,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2022-09-09
  • 使用Java8實(shí)現(xiàn)觀察者模式的方法(上)

    使用Java8實(shí)現(xiàn)觀察者模式的方法(上)

    本文給大家介紹使用java8實(shí)現(xiàn)觀察者模式的方法,涉及到j(luò)ava8觀察者模式相關(guān)知識(shí),對(duì)此感興趣的朋友一起學(xué)習(xí)吧
    2016-02-02
  • Java中實(shí)現(xiàn)分布式定時(shí)任務(wù)的方法

    Java中實(shí)現(xiàn)分布式定時(shí)任務(wù)的方法

    這篇文章主要介紹了Java中實(shí)現(xiàn)分布式定時(shí)任務(wù),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-01-01
  • nodejs連接dubbo服務(wù)的java工程實(shí)現(xiàn)示例

    nodejs連接dubbo服務(wù)的java工程實(shí)現(xiàn)示例

    這篇文章主要介紹了在項(xiàng)目遷移中,nodejs連接dubbo服務(wù)的java工程實(shí)現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步
    2022-03-03

最新評(píng)論