首頁 > 軟體

SpringBoot Mybatis批次插入Oracle資料庫資料

2022-08-25 14:02:19

前端資料

有如下需求,前端提交一個物件cabinData,儲存到資料表中,物件結構如下:

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

資料表結構

資料表是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資料庫資料的文章就介紹到這了,更多相關SpringBoot 批次插入Oracle 內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com