我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MyBatis实现批量插入数据,多重forEach循环

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MyBatis实现批量插入数据,多重forEach循环

批量插入数据,多重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 insert foreach

项目场景

报错 ,找不到参数

org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.binding.BindingException: Parameter ‘statusInfoId’ not found. Available parameters are [collection, list]

  @Mapper
public interface PatrolRecordMapper extends BaseMapper<PatrolRecord> {
    int insertList(@Param(value = "list") List<PatrolRecord> list);
}

mapper 换了很多种写法

    <insert id="insertList" parameterType="com.iricto.soft.patrol.entity.PatrolRecord">
        insert into patrol_record(status_info_id,route_id,place_name,patrol_time,
        patrol_user,patrol_class,`status`)
        VALUES
        <foreach collection="list" item="patrolRecord" separator=",">
            (patrolRecord.#{statusInfoId},
            patrolRecord.#{routeId},
            patrolRecord.#{placeName},
            patrolRecord.#{patrolTime},
            patrolRecord.#{patrolUser},
            patrolRecord.#{patrolClass},
            patrolRecord.#{status})
        </foreach>
    </insert>

mapper

    <insert id="insertList" parameterType="com.iricto.soft.patrol.entity.PatrolRecord">
        insert into patrol_record(status_info_id,route_id,place_name,patrol_time,
        patrol_user,patrol_class,`status`)
        VALUES
        <foreach collection="list" item="list"
                 open="(" separator="," close=")">
            list.#{statusInfoId},
            list.#{routeId},
            list.#{placeName},
            list.#{patrolTime},
            list.#{patrolUser},
            list.#{patrolClass},
            list.#{status}
        </foreach>
    </insert>

最后应该这么写才对 : mapper  

    <insert id="insertList" parameterType="com.iricto.soft.patrol.entity.PatrolRecord">
        insert into patrol_record(status_info_id,route_id,place_name,patrol_time,
        patrol_user,patrol_class,`status`)
        VALUES
        <foreach collection="list" item="patrolRecord" separator=",">
            (
            #{patrolRecord.statusInfoId},
            #{patrolRecord.routeId},
            #{patrolRecord.placeName},
            #{patrolRecord.patrolTime},
            #{patrolRecord.patrolUser},
            #{patrolRecord.patrolClass},
            #{patrolRecord.status})
        </foreach>
    </insert>

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MyBatis实现批量插入数据,多重forEach循环

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

MyBatis怎么实现批量插入数据,多重forEach循环

今天小编给大家分享一下MyBatis怎么实现批量插入数据,多重forEach循环的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧
2023-06-29

MyBatis批量插入几千条数据慎用foreach

经排查发现,主要时间消耗在往 MyBatis 中批量插入数据。mapper configuration是用 foreach 循环做的,差不多是这样。(由于项目保密,以下代码均为自己手写的demo代码)。
MyBatisforeach2024-12-01

MyBatis如何实现批量插入数据

本文小编为大家详细介绍“MyBatis如何实现批量插入数据”,内容详细,步骤清晰,细节处理妥当,希望这篇“MyBatis如何实现批量插入数据”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一、SQL实现示例假设我们
2023-07-04

MyBatis批量插入几千条数据为何慎用foreach

这篇文章主要介绍了MyBatis批量插入几千条数据为何慎用foreach问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2022-11-13

【mysql】向mysql数据库批量插入数据(循环)

错误插入  delimiter $$ //以delimiter来标记用$表示存储过程结束create procedure pre()//创建pre()存储方法begindeclare i int;//定义i变量set i=6001;while i<60
2021-08-13

Mysql循环插入数据的实现

目录mysql 循环插入数据WHILE…DO方式其他基本命令Mysql 循环插入10000条数据1.所以按自己想法,写个循环1W次随便插入数据测试2.执行过程Mysql 循环插入数据说明:首先需要设置delimiter。d
2022-08-17

MyBatis批量插入数据你还在用foreach?你们的服务器没崩?

近日,项目中有一个耗时较长的Job存在CPU占用过高的问题,经排查发现,主要时间消耗在往MyBatis中批量插入数据。

SQLServer批量插入数据怎么实现

在SQL Server中,可以使用以下方法来实现批量插入数据:使用INSERT INTO VALUES语句来一次性插入多条数据,例如:INSERT INTO table_name (column1, column2, column3) V
SQLServer批量插入数据怎么实现
2024-04-09

使用Spring Boot + MyBatis-Plus + ThreadPoolTaskExecutor实现批量插入百万级数据

我们充分利用了 Spring Boot 的强大功能、MyBatis-Plus 的便捷操作以及 ThreadPoolTaskExecutor 的高效并发处理能力,成功实现了百万级数据的批量插入。在实际应用中,还可以根据具体的业务需求和性能要求

如何利用MySqlBulkLoader实现批量插入数据

这篇文章主要介绍“如何利用MySqlBulkLoader实现批量插入数据”,在日常操作中,相信很多人在如何利用MySqlBulkLoader实现批量插入数据问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何利
2023-07-02

巧用Dictionary实现日志数据批量插入

对于C#中的Dictionary类相信大家都不陌生,这是一个Collection(集合)类型,可以通过Key/Value(键值对的形式来存放数据;该类最大的优点就是它查找元素的时间复杂度接近O(1),实际项目中常被用来做一些数据的本地缓存,

Java实现百万级数据量向MySQL批量插入

业务背景: 大数据向mysql表同步百万级数量,我们需要将大数据表里同步过来的数据分别向三张业务表做数据同步,最终将业务表的数据展示给前台进行相关业务操作。 数据量级 大数据表:700w数据量 三张业务表分别需要同步:23w、80w、680
2023-08-25

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录