SpringBoot中使用@Insert、@Update实现批量新增、更新

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

一、使用@Insert批量新增

数据库原始表数据
springboot批量新增,spring boot,java,junit

数据层接口

 // 批量新增
 @Insert("<script>" +
            "INSERT INTO userInfo" +
            "        (id,name,money)" +
            "        VALUES" +
            "        <foreach collection ='list' item='userInfo' separator =','>" +
            "            (#{userInfo.id}, #{userInfo.name}, #{userInfo.money})" +
            "        </foreach >" +
            "</script>")
    void insertUsers(@Param("list") List<userInfo> userInfos);

注意@Param(“list”) 引号中和foreach 中 collection 属性值必须写list,否则报错。item属性值写实体类的类名,首字母必须小写

接口测试:
由于在Apifox中是没有对应List的数据类型因此需要我们自己手写body形式 – json例如:

 [ 
    {  "id":4,
       "money":"102.3",
       "name":"XU"
       },
    {  "id":5,
        "money":"289.64",
       "name":"RC"
       }
        ] 

springboot批量新增,spring boot,java,junit

除了使用接口测试工具验证,我们还可以编写业务测试类进行测试:

package com.gy;

import com.gy.domain.userInfo;
import com.gy.service.UserService;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import java.util.ArrayList;
import java.util.List;

@RunWith(SpringJUnit4ClassRunner.class)
@SpringBootTest
public class test {
    @Autowired
    UserService userService;
    // 批量新增
    @Test
    public void test01(){
        List<userInfo> userInfos =new ArrayList<>();
        userInfos.add(new userInfo(4,"XU",102.3));
        userInfos.add(new userInfo(5,"RC",289.64));
        userService.insertUsers(userInfos);
    }
}

springboot批量新增,spring boot,java,junit

使用以上两种方式均可进行测试验证,此时数据均被批量新增成功!!!
springboot批量新增,spring boot,java,junit

二、使用@Update批量更新

数据库原始表数据见上图

数据层接口:

// 批量更新
@Update("<script>" +
        "   <foreach collection ='list' item='userInfo' separator =';'>" +
        "update userInfo set name=#{userInfo.name},money=#{userInfo.money} where id=#{userInfo.id}" +
        "</foreach>" +
        "</script>")
void updateList(@Param("list") List<userInfo> userInfos);

测试类:

 // 批量修改
    @Test
    public  void test04(){
        List<userInfo> userInfos =new ArrayList<>();
        userInfos.add(new userInfo(3,"NPL",1251.2));
        userInfos.add(new userInfo(4,"LL",37.64));
        userService.updateList(userInfos);
        List<userInfo> infos = userService.getAll();
        System.out.println(infos);
    }

此处需注意踩坑(本人在此处解决问题时耗费较长时间)
测试运行后出现报错信息,提示大概为sql语法出现异常,然而多次排查各种(数据库、字段、表名等等…)问题均无果
springboot批量新增,spring boot,java,junit
发现sql能够在navicat上面正常的运行,于是就只有看配置。后来了解到了批量必然要执行多行sql。但是mybatis默认是不开启多行sql执行的,于是修改配置,开启MySQL多行sql执行。

url: jdbc:mysql://127.0.0.1:3306/test?serverTimezone=UTC&allowMultiQueries = true

开启多行sql执行:在数据库连接信息配置中 url后面加上:`allowMultiQueries = true

可以看到上诉问题立刻得到了解决☺
springboot批量新增,spring boot,java,junit
springboot批量新增,spring boot,java,junit

mysql的url参数详解:
springboot批量新增,spring boot,java,junit文章来源地址https://www.toymoban.com/news/detail-700241.html

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

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

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

相关文章

  • Mybatis之批量更新数据(批量update)

    前言 当我们使用mybatis的时候,可能经常会碰到一批数据的批量更新问题,因为如果一条数据一更新,那每一条数据就需要涉及到一次数据库的操作,包括网络IO以及磁盘IO,可想而知,这个效率是非常低下的。而平时我们很少直接使用原生jdbc直接操作数据库,而是会使用比较

    2024年02月11日
    浏览(34)
  • for循环中循环一次提交一次 insert update 关闭事务 spring springboot mybatis

     在方法上直接加如下注解: 在测试的时候,有时候会希望在for循环中,代码循环一次就提交一次事务。 最简单的方式,就是关闭事务,不需要事务。添加注解如下: 如果说是真的在生产上有这样的需要,每循环一次就提交事务,那就需要手动控制事务了。 需要这几行代码

    2024年02月07日
    浏览(33)
  • FieldFill.INSERT与FieldFill.UPDATE使用

    首先在bean对象的class里面对应字段上面加上 或者 如果需要同时指定新增和修改 则添加 然后添加下配置类

    2024年02月16日
    浏览(31)
  • Java8 实现批量插入和更新,SpringBoot实现批量插入和更新,Mybatis实现批量插入和更新

    基于mybatis实现的批量插入和更新 由于直接执行批量所有数据可能会出现长度超出报错问题,使用如下方式即可解决 原理还是分配执行,这里的100就是设定每次执行最大数 这里使用插入作为例子,也可以使用批量更新 更新的写法

    2024年02月12日
    浏览(38)
  • django 批量创建bulk_create和批量更新bulk_update

    以创建1万个对象为例,相比save() 循环和save() 事务,bulk_效率是save()循环保存的百倍,是事务处理的近10倍: 用法: 用法:

    2024年02月11日
    浏览(39)
  • Oracle数据库update语句用法,多表批量更新对应的字段值

    日常工作经常会遇到参照某个表格,更新主表对应字段的值 一般可以用excel的VLOOKup函数进行查找匹配,但是这种方法需要将表从数据库中导出,更新完了之后再导回数据库中。 我们用update语句可以很方便在数据库里完成更新。 语句: update 要修改数据的表名 set 修改的列1=(

    2024年02月06日
    浏览(35)
  • Mybatis-plus通过其他字段批量更新或新增

    根据某个或者多个非ID字段进行批量更新 示例通过名称与id两个字段更新 引用mybatis-plus根据某个指定字段批量更新数据库 通过其他字段批量更新或新增

    2024年02月12日
    浏览(36)
  • springboot+es批量新增、批量修改、根据内部id批量查询

    pom.xml配置 yml配置 EsConfig配置 ElasticSearchConfig 配置 启动类配置 //批量操作的对象 批量修改 批量新增 根据es内部id批量查询数据

    2024年02月11日
    浏览(37)
  • 【postgresql 基础入门】UPSERT语句,INSERT违反约束条件时可以转变为UPDATE语句,UPDATE与INSERT的合体

    ​ 专栏内容 : postgresql内核源码分析 手写数据库toadb 并发编程 个人主页 :我的主页 管理社区 :开源数据库 座右铭:天行健,君子以自强不息;地势坤,君子以厚德载物. 入门准备 postgrersql基础架构 快速使用 初始化集群 数据库服务管理 psql客户端使用 pgAdmin图形化客户端

    2024年03月12日
    浏览(40)
  • 使用saveOrUpdateBatch实现批量插入更新数据

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

    2024年02月11日
    浏览(41)

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

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

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

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

二维码1

领取红包

二维码2

领红包