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,表結構為:
後端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 內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- mybatis條件語句中帶數組參數的處理
- mybatis實現批量插入並返回主鍵(xml和註解兩種方法)
- mybatis使用oracle進行添加數據的方法
- MyBatis中foreach標簽的collection屬性的取值方式
- MySQL和Oracle批量插入SQL的通用寫法示例