Java8 实现批量插入和更新,SpringBoot实现批量插入和更新,Mybatis实现批量插入和更新

这篇具有很好参考价值的文章主要介绍了Java8 实现批量插入和更新,SpringBoot实现批量插入和更新,Mybatis实现批量插入和更新。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

前言

基于mybatis实现的批量插入和更新
由于直接执行批量所有数据可能会出现长度超出报错问题,使用如下方式即可解决

实现

原理还是分配执行,这里的100就是设定每次执行最大数

	/**
	 * 封装使用批量添加或修改数据库操作
	 *
	 * @param list 集合
	 * @param consumer 需要执行的任务 (Consumer lambda表达式方法引用的任务目标)
	 * @param asyn 是否异步
	 * @param <T> 自定义类型
	 */
	public static <T> void insertBatch(List<T> list, Consumer<List<T>> consumer, boolean asyn) {
		int max = 100; // 每次批量限制数
		if (list.size() > max) {
			List<List<T>> allList = new ArrayList<>();
			List<T> tempList = new ArrayList<>();
			for (int i = 0; i < list.size(); i++) {
				tempList.add(list.get(i));
				if ((i % max) == 0) {
					allList.add(tempList);
					tempList = new ArrayList<>();
				}
			}
			if (tempList.size() > 0) {
				allList.add(tempList);
			}
			if(asyn) {
				// 多线程遍历(异步)-这里直接遍历无需accept(接口式方法简化)
				allList.parallelStream().forEach(consumer);
			}else {
				// 遍历(同步)-这里直接遍历无需accept(接口式方法简化)
				allList.forEach(consumer);
			}
		} else {
			// 执行泛型集合数据
			consumer.accept(list);
		}
	}

使用

xml

这里使用插入作为例子,也可以使用批量更新

	<insert id="insertBatchUser">
        insert into sys_user(
        	name,
        	sex
        )values 
        <foreach collection="list" item="item" index="index" separator=",">
	        (#{item.name}, #{item.sex})
	    </foreach>
    </insert>

更新的写法文章来源地址https://www.toymoban.com/news/detail-658340.html

    <update id="updateBatchUser">
        <foreach collection="list" item="item" index="index" separator=";">
            update sys_user
            <set>
                <if test="item.name != null and item.name != ''">
                    name = #{item.name},
                </if>
                update_date = #{item.updateDate}
                <where>
                    id = #{item.id}
                </where>
            </set>
        </foreach>
    </update>

批量数据

	List<UserBean> list = new ArrayList<>();
	UserBean user1 = new UserBean();
	user1.setName("张三");
	user1.setSex("男");
	UserBean user2 = new UserBean();
	user2.setName("李四");
	user2.setSex("男");
	list.add(user1);
	list.add(user2);

调用

	// 执行批量插入或修改
	Consumer<List<UserBean>> consumer = v -> dao.insertBatchUser(v);
	insertBatch(list, consumer, true)

到了这里,关于Java8 实现批量插入和更新,SpringBoot实现批量插入和更新,Mybatis实现批量插入和更新的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Springboot Mybatis 不存在插入数据,存在则更新数据

    是不是经常看到代码, 查一下数据库,如果存在数据,就做更新语句调用; 如果不存在,就插入。 今天该篇介绍的 是使用     INSERT INTO        ON DUPLICATE KEY UPDATE        来实现我们上述的场景, 不需要自己再判断来判断去的。 ON DUPLICATE key update 是根据主键索引或者唯一

    2024年02月13日
    浏览(22)
  • 使用saveOrUpdateBatch实现批量插入更新数据

    saveOrUpdateBatch 是 Hibernate 中的一个方法,可以用来批量插入或更新数据。这个方法的参数是一个 List,里面可以存储多个实体对象。当 Hibernate 执行这个方法时,会检查每个实体对象是否存在主键,如果存在主键就执行 update 操作,否则执行 insert 操作。 使用 saveOrUpdateBatch 的代

    2024年02月11日
    浏览(38)
  • springboot使用aop排除某些方法,更新从另外一张表,从另外一张表批量插入

    在Spring Boot中使用AOP时,如果想要排除某些方法不被切面所影响,可以通过使用切面表达式中的!within来实现。以下是一个示例: 在上面的示例中,@Before注解用于定义切面的beforeAdvice方法。execution(* com.example.service. . (…))表示切入所有com.example.service包下的方法。而!wit

    2024年02月13日
    浏览(32)
  • Mysql 实现批量插入对已存在数据忽略或更新

    对已存在的数据进行 忽略/更新 ,需要唯一索引/主键。 唯一索引可为多个字段的联合索引,比如根据我提供的sql中,我需要``name + age`不重复,则可把这2个字段联合创建为唯一索引 创建联合唯一索引的sql 批量插入对已存在数据忽略 批量插入对已存在数据更新 笔者这里只举

    2024年02月15日
    浏览(32)
  • Mybatis-Plus的SQL注入器实现批量插入/修改,效率比较

    mysql支持一条sql语句插入多条数据。但是Mybatis-Plus中默认提供的saveBatch、updateBatchById方法并不能算是真正的批量语句,而是遍历实体集合执行INSERT_ONE、UPDATE_BY_ID语句。 mybatis-plus虽然做了分批请求、一次提交的处理。但如果jdbc不启用配置rewriteBatchedStatements,那么批量提交的s

    2024年02月11日
    浏览(37)
  • java实现批量插入数据

    日常工作或者学习中,可能会遇到批量插入数据的需求,一般情况下数据量少的时候,我们会直接调用批量接口插入数据即可,当数据量特别大时,可能由于数据库限制,插入的数据最多不能超过100条(假如限制100条),就算是数据库支持一次性插入千条也会耗内存,如果使用

    2024年02月11日
    浏览(47)
  • Mybatis批量插入

    使用Mybatis框架批量插入的3种方法:多次调用insert方法、foreach标签、batch模式 后端java代码:

    2024年02月12日
    浏览(49)
  • Mybatis批量插入、修改

            在 MyBatis 中, foreach 标签用于遍历集合类型的条件,并且可以将多个参数值拼接成为 SQL 语句的一个部分,通常被用于批量插入或更新等操作。  foreach属性及介绍          属性 介绍 collection 集合名称 item 字符别名 index 索引别名 open 循环前缀 close 循环后缀 separato

    2024年02月07日
    浏览(27)
  • Spring Boot Elasticsearch7.6.2实现创建索引、删除索引、判断索引是否存在、获取/添加/删除/更新索引别名、单条/批量插入、单条/批量更新、删除数据、递归统计ES聚合的数据

    注意:我的版本是elasticsearch7.6.2、spring-boot-starter-data-elasticsearch-2.5.6 引入依赖 有时候你可能需要查询大批量的数据,建议加上下面配置文件

    2024年02月13日
    浏览(52)
  • Mybatis批量插入方式有哪些

    MyBatis批量插入有多种写法,最后博主总结一些常见的批量插入写法供大家参考 使用XML配置文件进行批量插入:在XML映射文件中使用 insert 标签,并通过 foreach 标签迭代批量数据,然后在SQL语句中使用 VALUES 。 使用Java注解进行批量插入:在实体类上使用 @Insert 注解,并

    2024年02月11日
    浏览(34)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包