中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

SpringBoot?Mybatis怎么批量插入Oracle數據庫數據

發布時間:2022-08-25 14:45:17 來源:億速云 閱讀:244 作者:iii 欄目:開發技術

這篇文章主要介紹“SpringBoot Mybatis怎么批量插入Oracle數據庫數據”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“SpringBoot Mybatis怎么批量插入Oracle數據庫數據”文章能幫助大家解決問題。

前端數據

有如下需求,前端提交一個對象cabinData,保存到數據表中,對象結構如下:

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

數據表結構

數據表是oracle,表結構為:

SpringBoot?Mybatis怎么批量插入Oracle數據庫數據

后端Controller:

 @PostMapping("/savecabin")
 public AjaxResult savecabin(@RequestBody Map<String,Object> postCabinData){
 
     // 獲取map中的參數
     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時,執行批量刪除;船艙
     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形成數組參數,入參批量刪除方法deleteDraftCabinByIds

  • 批量插入時,調用service的insertDraftCabins方法,傳入四個參數(ballastCabinData,shipId,"壓艙水",shipName)

mapper

 public int insertDraftCabins(@Param("DraftCabin")List DraftCabin, @Param("shipId")Integer shipId, @Param("cabinType")String cabinType,@Param("shipName")String shipName) ;

解析:

mapper中,多個參數使用@Param注解來接收,在mybaits的xml中,調用注解名稱。

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,接收多個參數,這時不要添加parameterType屬性,useGeneratedKeys="false",一定要添加;

  • foreach的collection是要遍歷的對象,這里填寫mapper中的注解名稱;

orcale的批量插入方法與mysql有很大區別,這里需要注意以下:

 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數據庫數據”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

新晃| 库车县| 青浦区| 年辖:市辖区| 石城县| 炉霍县| 顺义区| 竹溪县| 特克斯县| 临洮县| 普兰县| 毕节市| 武义县| 甘谷县| 东平县| 冕宁县| 德清县| 台前县| 琼结县| 尼木县| 澄城县| 沙雅县| 城市| 台中市| 藁城市| 陈巴尔虎旗| 张家港市| 常德市| 于都县| 望都县| 鄂温| 白朗县| 崇阳县| 大连市| 富川| 福州市| 皋兰县| 凭祥市| 迭部县| 安溪县| 巧家县|