MyBatis中批量插入資料,多重forEach迴圈
在業務開發過程中,遇到批量插入時,需要進行多重forEach迴圈的情況。下面是一個實際應用:
public class SysRoleData extends DataEntity<SysRoleData> { private static final long serialVersionUID = 1L; private String kind; //類別(1:按部門2:按角色) private String roleId; // role_id private String roleName; //角色名稱 private String officeId; //office_id private String officeName; //部門名稱 private String type; // 1.品牌 2.品類 3.品牌&品類 private String dataId; // 資料ID品牌 private String dataName; //資料名稱品牌 private String dataIds; // 資料ID品類 private String dataNames; //資料名稱品類 private String groupNo; //分組標識 private String useable; //是否可用(1:可用,0:不可用) private String remarks; //備註 private List<String> officeIdList = Lists.newArrayList(); private List<String> roleIdList = Lists.newArrayList(); private List<BrandCategoryVO> dataList = Lists.newArrayList(); public SysRoleData() { super(); } public SysRoleData(String id){ super(id); } public String getKind() { return kind; } public void setKind(String kind) { this.kind = kind; } @Length(min=0, max=45, message="role_id長度必須介於 0 和 45 之間") public String getRoleId() { return roleId; } public void setRoleId(String roleId) { this.roleId = roleId; } public String getRoleName() { return roleName; } public void setRoleName(String roleName) { this.roleName = roleName; } public String getOfficeName() { return officeName; } public void setOfficeName(String officeName) { this.officeName = officeName; } @Length(min=0, max=45, message="office_id長度必須介於 0 和 45 之間") public String getOfficeId() { return officeId; } public void setOfficeId(String officeId) { this.officeId = officeId; } @Length(min=0, max=4, message="品類長度必須介於 0 和 45 之間") public String getType() { return type; } public void setType(String type) { this.type = type; } @NotNull public String getDataId() { return dataId; } public void setDataId(String dataId) { this.dataId = dataId; } public String getDataName() { return dataName; } public void setDataName(String dataName) { this.dataName = dataName; } public String getDataIds() { return dataIds; } public void setDataIds(String dataIds) { this.dataIds = dataIds; } public String getDataNames() { return dataNames; } public void setDataNames(String dataNames) { this.dataNames = dataNames; } public String getUseable() { return useable; } public void setUseable(String useable) { this.useable = useable; } public String getRemarks() { return remarks; } public void setRemarks(String remarks) { this.remarks = remarks; } public List<BrandCategoryVO> getDataList() { return dataList; } public void setDataList(List<BrandCategoryVO> dataList) { this.dataList = dataList; } public List<String> getOfficeIdList() { return officeIdList; } public void setOfficeIdList(List<String> officeIdList) { this.officeIdList = officeIdList; } public List<String> getRoleIdList() { return roleIdList; } public void setRoleIdList(List<String> roleIdList) { this.roleIdList = roleIdList; } public String getGroupNo() { return groupNo; } public void setGroupNo(String groupNo) { this.groupNo = groupNo; } }
如上所示為一個實體類,會有dataList和roleIdList或officeIdList,在批量插入時從而形成多重迴圈。
上圖為列表頁面,
上圖為新增頁面。部門名稱和品牌,品類名稱支援多選,而在儲存時,需要將其拆分儲存。在查詢時通過group_concat函式進行聚合展示在列表頁面。
故在批量插入資料時:
<insert id="insert"> INSERT INTO sys_role_data( kind, role_id, office_id, type, data_id, data_name, group_no, useable, remarks, create_date, create_by, update_date, update_by )VALUES <if test="kind != null and kind == 0"> <foreach collection="officeIdList" item="officeId" separator=","> <foreach collection="dataList" item="data" separator=","> ( #{kind}, null, #{officeId}, #{type}, #{data.id}, #{data.name}, #{groupNo}, #{useable}, #{remarks}, #{createDate}, #{createBy.id}, #{updateDate}, #{updateBy.id} ) </foreach> </foreach> </if> <if test="kind != null and kind == 1"> <foreach collection="roleIdList" item="roleId" separator=","> <foreach collection="dataList" item="data" separator=","> ( #{kind}, #{roleId}, null, #{type}, #{data.id}, #{data.name}, #{groupNo}, #{useable}, #{remarks}, #{createDate}, #{createBy.id}, #{updateDate}, #{updateBy.id} ) </foreach> </foreach> </if> </insert>
由上面sql可以看出,根據kind不同,進行相應的雙重forEach迴圈插入資料。
相關文章
- mybatis foreach迴圈MyBatis
- mybatis插入資料、批量插入資料MyBatis
- MyBatis 批量插入資料MyBatis
- MyBatis xml foreach迴圈語句MyBatisXML
- 還用foreach在MyBatis批量插入資料,伺服器還沒崩?MyBatis伺服器
- 每秒迴圈插入資料
- MyBatis Plus 批量資料插入功能,yyds!MyBatis
- mybatis list作為引數 foreach迴圈MyBatis
- java中批量插入資料jdbc hibernate Mybatis使用方式JavaJDBCMyBatis
- mybatis中使用foreach構造多like查詢及批量插入MyBatis
- 使用Mybatis批量插入大量資料的實踐MyBatis
- java跳出多重迴圈Java
- JavaScript的map迴圈、forEach迴圈、filter迴圈、reduce迴圈、reduceRight迴圈JavaScriptFilter
- Mybatis批量插入Oracle、MySQLMyBatisOracleMySql
- Java通過Mybatis實現批量插入資料到Oracle中JavaMyBatisOracle
- 編寫迴圈插入表資料的語句。
- oracle批量插入資料Oracle
- Redis從檔案中批量插入資料Redis
- 向表中插入大批量資料
- foreach迴圈和記憶體中的陣列記憶體陣列
- js中為什麼for迴圈比forEach效能高?JS
- js迴圈(for/for in/forEach/map/for of)詳解JS
- 再學Java 之 foreach迴圈Java
- thinkphp中volist的多重迴圈,標籤巢狀PHP巢狀
- Java入門學習-學習if & else,for迴圈,foreach迴圈,while迴圈的用法。JavaWhile
- Mybatis框架:foreach迴圈遍歷欄位(為了解決動態表、動態欄位查詢資料)MyBatis框架
- C#程式設計基礎第七課:C#中的基本迴圈語句:while迴圈、do-while迴圈、for迴圈、foreach迴圈的使用C#程式設計While
- MyBatis Batch Update Exception使用foreach批量update出錯MyBatisException
- 使用MySqlBulkLoader批量插入資料MySql
- 大表資料插入批量提交
- 海量資料處理_批量插入
- SQL語句批量插入資料SQL
- SqlBulkCopy 複製批量插入資料SQL
- 14,javase程式碼實戰-迴圈控制——foreach迴圈的使用(五)Java
- Mybatis中mapper檔案中的兩層迴圈MyBatisAPP
- 【MyBatis】幾種批量插入效率的比較MyBatis
- JavaScript裡的迴圈方法:forEach,for-in,for-ofJavaScript
- mysql迴圈插入資料、生成隨機數及CONCAT函式MySql隨機函式