mybatis中foreach批量插入并返回主键

背景

    批量插入多条数据,插入成功之后每条数据中需要返回自增主键.

处理办法

1.确定项目中mybatis版本,要求3.3.1以上.

    查看springboot中项目版本方法:
pom.xml中进入依赖(Ctrl+点击进入):

  <dependency><groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-starter</artifactId><version>2.1.3</version></dependency>

进入之后发现也是继承了一个父类
在这里插入图片描述
按照上面的方法进入之后可以查看mybatis版本:
在这里插入图片描述

2.foreach标签批量插入返回主键

mapper:

int addStaffUseItemRecord(List<CashUseItem> cashUseItemList);

实体类:

public class CashUseItem implements Serializable {private static final long serialVersionUID = 116859051074041617L;private Integer programId;private Integer programNum;private Integer useItemId;private Integer useRecordId}

配置文件:

 <insert id="addStaffUseItemRecord"  useGeneratedKeys="true" keyProperty="useItemId">insert into manage_staff_use_record_item (program_id,num) values<foreach collection="list" separator="," item="cashUseItem">(#{cashUseItem.programId},#{cashUseItem.programNum})</foreach></insert>

测试:

 List<CashUseItem> cashUseItemList = new ArrayList<>();CashUseItem cashUseItem = new CashUseItem();cashUseItem.setProgramId(1);cashUseItem.setProgramNum(1);cashUseItem.setUseRecordId(5);CashUseItem cashUseItem1 = new CashUseItem();cashUseItem1.setProgramId(2);cashUseItem1.setProgramNum(2);cashUseItem1.setUseRecordId(5);cashUseItemList.add(cashUseItem);cashUseItemList.add(cashUseItem1);int y = cashMapper.addStaffUseItemRecord(cashUseItemList);System.out.println(cashUseItemList);

输出结果:

[CashUseItem(programId=1, programNum=1, packageId=0, useItemId=29), CashUseItem(programId=2, programNum=2, packageId=0, useItemId=30)]

遇到到坑:
    原业务处理中需要传递一个对应多个集合的数据id:useRecordId,最初的处理是下面:

[CashUseItem(programId=1, programNum=1, packageId=0, useItemId=31, useRecordId=5), CashUseItem(programId=2, programNum=2, packageId=0, useItemId=32, useRecordId=5)]

但是执行sql的时候会有入表记录,但是控制台会报错:

Could not determine which parameter to assign generated keys to. Note that when there are multiple parameters, 'keyProperty' must include the parameter name (e.g. 'param.id'). Specified key properties are [useRecordId] and available parameters are [cashUseItemList, useRecordId, param1, param2]

尝试多次发现,对于foreach批量插入操作,不支持多参数处理,在不改变原有的逻辑的处理方式就是将dataId放到集合中即可.

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/488025.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

docker运行onlyoffice,并配置https访问【参考仅用】

官方说明&#xff1a; Installing ONLYOFFICE Docs for Docker on a local server - ONLYOFFICEhttps://helpcenter.onlyoffice.com/installation/docs-developer-install-docker.aspx 一、容器端口、目录卷映射 sudo docker run --name容器名称 --restartalways -i -t -d -p…

国家建筑装配式内装产业基地在沪成立,副主任单位优积科技协同助推绿色低碳循环发展

上海市室内装饰行业协会装配式内装产业专业委员会成立大会暨“国家建筑装配式内装产业基地”项目启动会于3月21日下午1点在上海光大酒店隆重举行。出席此次活动的包括市装协会长徐国俭&#xff0c;市装协党支部书记兼秘书长丛国梁&#xff0c;市装协装配式内装委主任顾泰昌&…

汇编反外挂

在软件保护领域&#xff0c;尤其是游戏保护中&#xff0c;反外挂是一个重要的议题。外挂通常指的是一种第三方软件&#xff0c;它可以修改游戏数据、操作游戏内存或提供其他作弊功能&#xff0c;从而给玩家带来不公平的优势。为了打击外挂&#xff0c;游戏开发者会采取一系列措…

【计网】TCP的三次握手四次挥手

&#x1f34e;个人博客&#xff1a;个人主页 &#x1f3c6;个人专栏&#xff1a;JAVA ⛳️ 功不唐捐&#xff0c;玉汝于成 目录 前言 正文 三次握手&#xff08;Connection Establishment&#xff09; 四次挥手&#xff08;Connection Termination&#xff09; 结语 我…

协议的概念+本质+作用+最终表现形式,网络问题(技术+应用+解决的协议+存在原因),主机的对称性

目录 协议 概念 示例 -- 摩斯密码 本质 作用 网络问题 引入 技术问题 应用问题 主机的对称性 问题对应的协议 问题出现的原因 理解协议(代码层面) 举例 -- 快递单 协议的最终表现形式 协议被双方主机认知的基础 协议 概念 协议是在计算机通信和数据传输中规定通…

2024年 最新python调用ChatGPT实战教程

2024年 最新python调用ChatGPT实战教程 文章目录 2024年 最新python调用ChatGPT实战教程一、前言二、具体分析1、简版程序2、多轮对话3、流式输出4、返回消耗的token 一、前言 这个之前经常用到&#xff0c;简单记录一下,注意目前chatgpt 更新了&#xff0c;这个是最新版的&am…

一款好用的多线程碰撞工具

host_scan 介绍 多线程host碰撞&#xff0c;发现更多资产。 把域名放在host.txt 把ip放在ip.txt&#xff0c;跑出的结果存放在ok.txt里面。 一开始输出&#xff08;ok.txt&#xff09;的内容可能都是脏数据&#xff0c;需要更关注后面输出(ok.txt)的那些数据&#xff01;&a…

openssl 生成nginx自签名的证书

1、命令介绍 openssl req命令主要的功能有&#xff0c;生成证书请求文件&#xff0c; 查看验证证书请求文件&#xff0c;还有就是生成自签名证书。 主要参数 主要命令选项&#xff1a; -new :说明生成证书请求文件 -x509 :说明生成自签名证书 -key :指定已…

18个惊艳的可视化大屏(第七辑):场馆与园区方向

本期分享智慧场馆和智慧园区方向的可视化大屏&#xff0c;各位老铁上车&#xff0c;坐稳了&#xff0c;上图啦。

172基于matlab的MPPT智能算法

基于matlab的MPPT智能算法&#xff0c;通过细菌觅食进行优化。算法引入了趋向性操作&#xff0c;用以进行局部范围内的最优寻找&#xff1b;引入了复制操作&#xff0c;用以避免种群更新盲目随机性&#xff0c;加快了算法的收敛速度&#xff1b;引入了迁徙操作用以避免算法陷入…

IO进程线程复习

标准IO&#xff1a; 1.打开文件 #include<myhead.h>int main(int argc, const char *argv[]) {//定义文件指针FILE *fpNULL;//以只读的形式打开文件//fpfopen("./text.txt","r");//以只写的形式打开文件fpfopen("./time.c","w"…

PyTorch:transforms.Normalize()函数详解

PyTorch&#xff1a;transforms.Normalize()函数详解 &#x1f308; 个人主页&#xff1a;高斯小哥 &#x1f525; 高质量专栏&#xff1a;Matplotlib之旅&#xff1a;零基础精通数据可视化、Python基础【高质量合集】、PyTorch零基础入门教程 &#x1f448; 希望得到您的订阅和…