mybatis-plus saveOrUpdateBatchByUniquekey 插入或更新按自定义唯一索引

mybatis-plus 自带的saveOrUpdateBatch 是以主键来判断插入 或更新的, 如何根据唯一索引实现呢?

## mysql 定义唯一索引 unique key: (salary_date, tenant_id, type, id_no)@Transactional(rollbackFor = Exception.class)
@Override
public boolean saveOrUpdateBatchByUniqueKey(List<Salary> list) {// 这里主要是查询唯一约束对应的记录是否存在return SqlHelper.saveOrUpdateBatch(entityClass, this.mapperClass, super.log, list, DEFAULT_BATCH_SIZE, (sqlSession, entity) -> {LambdaQueryWrapper<Salary> queryWrapper = Wrappers.<Salary>lambdaQuery().eq(Salary::getSalaryDate, entity.getSalaryDate()).eq(Salary::getTenantId, entity.getTenantId()).eq(Salary::getType, entity.getType()).eq(Salary::getIdNo, entity.getIdNo());Map<String, Object> queryParam = CollectionUtils.newHashMapWithExpectedSize(1);queryParam.put(com.baomidou.mybatisplus.core.toolkit.Constants.WRAPPER, queryWrapper);return CollectionUtils.isEmpty(sqlSession.selectList(getSqlStatement(SqlMethod.SELECT_LIST), queryParam));}, (sqlSession, entity) -> {LambdaUpdateWrapper<Salary> updateWrapper = new LambdaUpdateWrapper<>();updateWrapper.eq(Salary::getSalaryDate, entity.getSalaryDate()).eq(Salary::getTenantId, entity.getTenantId()).eq(Salary::getType, entity.getType()).eq(Salary::getIdNo, entity.getIdNo());Map<String, Object> param = CollectionUtils.newHashMapWithExpectedSize(2);param.put(com.baomidou.mybatisplus.core.toolkit.Constants.ENTITY, entity);param.put(com.baomidou.mybatisplus.core.toolkit.Constants.WRAPPER, updateWrapper);sqlSession.update(getSqlStatement(SqlMethod.UPDATE), param);});
}

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

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

相关文章

前端Sonar部署的步骤

下载并安装Java jdk&#xff0c;Sonar运行必须依赖jdk。下载sonarqube和sonar-scanner。配置环境变量&#xff0c;打开.bash_profile文件&#xff0c;添加以下内容&#xff1a; # jdkexport JAVA_17_HOMEjdk安装地址export JAVA_HOME$JAVA_17_HOMEexport PATH$JAVA_HOME/bin:$P…

xlrd库的安装和应用

目录 前言 安装 注意 优点 通用知识 函数方法 使用范例 使用心得 前言 xlrd库特别适合需要处理Excel文件中数据的任务. 同时&#xff0c;需要注意的是&#xff0c;xlrd 主要用于读取Excel文件。如果需要写入Excel文件&#xff0c;可以结合其他库如 openpyxl或者xlsxwri…

嵌入式学习36-TCP要点及http协议

TCP发送文件的粘包问题 1. 例&#xff1a; 发端 1.flv-------->收端 1.flv csfga 2.解决 1. sleep&#xff08;1&#xff09; 延时发送 2.自…

C++ 实战项目之 Boost 搜索引擎

项目地址&#xff1a;https://gitee.com/Vertas/boost-searcher-project 1. 项目背景 日常生活中我们使用过很多搜索引擎&#xff0c;比如百度&#xff0c;搜狗&#xff0c;360搜索等。我们今天是要实现一个像百度这样的搜索引擎嘛&#xff1f;那是不可能的&#xff0c;因为像…

2024年新版CMS内容管理使用,不用回退老版本 使用最新小程序云开发cms内容模型

一&#xff0c;问题描述 最近越来越多的同学找石头哥&#xff0c;说cms用不了&#xff0c;其实是小程序官方最近又搞大动作了&#xff0c;偷偷的升级的云开发cms&#xff08;内容管理&#xff09;以下都称cms&#xff0c;不升级不要紧&#xff0c;这一升级&#xff0c;就导致我…

【三维重建】VastGaussian:用于大场景重建的大3D Gaussian(CVPR 2024)

题目&#xff1a;VastGaussian: Vast 3D Gaussians for Large Scene Reconstruction 来源&#xff1a;清华大学&#xff1b;华为诺亚&#xff1b;中国科学院 链接&#xff1a;https://vastgaussian.github.io/ 总结&#xff1a;VastGaussian&#xff1a;基于3D GS的分块优化重…

7-18 彩虹瓶(Python)

彩虹瓶的制作过程&#xff08;并不&#xff09;是这样的&#xff1a;先把一大批空瓶铺放在装填场地上&#xff0c;然后按照一定的顺序将每种颜色的小球均匀撒到这批瓶子里。 假设彩虹瓶里要按顺序装 N 种颜色的小球&#xff08;不妨将顺序就编号为 1 到 N&#xff09;。现在工…

系统质量属性与架构评估

本博客地址&#xff1a;https://security.blog.csdn.net/article/details/136565452 一. 软考系统质量属性 1、软件系统质量属性是一个系统的可测量或可测试的属性&#xff0c;基于软件系统的生命周期&#xff0c;可将软件系统的质量属性分为开发期质量属性和运行期质量属性 …

仿牛客项目Day02:http、调试、日志、git

http状态码 后端调试 f8&#xff1a;逐行执行 f7&#xff1a;进入语句内部 f9&#xff1a;执行到下一个断点 前端调试 f10&#xff1a;逐行调试 f11&#xff1a;进入语句内部 f8&#xff1a;执行到下一个断点 日志 按照级别开启日志 日志的测试类 比如把application里…

Java --- springcloud初始项目创建

目录 一、cloud项目创建 1.1、项目编码规范 1.2、注解生效激活 1.3、导入父工程maven的pom依赖 二、创建子工程并导入相关pom依赖 2.1、相关配置文件 2.1.1、数据库配置文件内容 2.1.2、自动生成文件配置内容 三、创建微服务8001子工程 3.1、导入相关pom依赖 3.…

数据结构从入门到精通——栈

栈 前言一、栈1.1栈的概念及结构1.2栈的实现1.3栈的面试题 二、栈的具体实现代码栈的初始化栈的销毁入栈出栈返回栈顶元素返回栈中的元素个数检测是否为空Stack.hStack.ctest.c 前言 栈&#xff0c;作为一种后进先出&#xff08;LIFO&#xff09;的数据结构&#xff0c;在计算…

NTFS Disk by Omi NTFS for mac v1.1.4中文版

NTFS Disk by Omi NTFS for Mac&#xff1a;NTFS文件系统的无缝桥梁 软件下载&#xff1a;NTFS Disk by Omi NTFS for mac v1.1.4中文版 &#x1f310; 跨平台访问&#xff0c;文件无阻 NTFS Disk by Omi NTFS for Mac 为您的Mac提供了对NTFS文件系统的无缝访问。无论您是在Win…

Unity插件之天气系统UniStorm

首先呢&#xff0c;它是一款强大的动态昼夜天气系统&#xff0c;能够以较快的帧速率创建AAA级动态生成的天气、照明和天空&#xff0c;并且具有300多个可定制的组件&#xff0c;允许用户创建任何可以想象的环境。 第一步&#xff1a;他需要两个物体Camera摄像机、Player播放器…

鸿蒙开发-UI-动画-页面内动画

鸿蒙开发-UI-组件2 鸿蒙开发-UI-组件3 鸿蒙开发-UI-气泡/菜单 鸿蒙开发-UI-页面路由 鸿蒙开发-UI-组件导航-Navigation 鸿蒙开发-UI-组件导航-Tabs 鸿蒙开发-UI-图形-图片 鸿蒙开发-UI-图形-绘制几何图形 鸿蒙开发-UI-图形-绘制自定义图形 文章目录 前言 一、概述 二、页面内…

数学中不能随心所欲乱用辅助函数

在“On the divisor and circle problems"论文中(J.Number Theory, 29(1988), 60-93)&#xff0c;H.Iwaniec和C.J.Mozzochi用了好几个光滑辅助函数&#xff08;"光滑"指无穷次可导&#xff09;&#xff0c;其中一个光滑函数要求满足&#xff1a;(a)当x<1或x&…

分析:一周销量破千万的《幻兽帕鲁》到底用的什么技术?

在《幻兽帕鲁》这款游戏中&#xff0c;玩家沉浸于创建一个属于自己的英雄角色。从选择种族到定制外观&#xff0c;每一步都体现了建造者模式的精髓。 建造者模式在游戏中的体现 玩家在游戏中创建角色&#xff0c;就像是在逐步构建一个复杂对象。首先&#xff0c;有一个基本的…

新一代信息技术下,AI如何重塑售前工作

近期&#xff0c;“新质生产力”一词犹如一颗璀璨的新星&#xff0c;频繁地在各大媒体平台上抢占热点位置&#xff0c;引发了大家的关注。关于“新质生产力”官方的解释是科技创新驱动经济高质量发展的必然产物&#xff0c;它代表着新一轮科技革命和产业变革的重要方向。 在今…

finishConnect(..) failed: Connection refused,服务本地正常服务器网关报400,nacos服务实例不能下线

①application里固定ip # Spring spring:cloud:inetutils:preferred-networks: 127.0.0.1 ②找到nacos服务下的protocol&#xff0c;删除下面所有&#xff0c;/nacos-server/data/protocol&#xff0c;删了不会有问题&#xff0c;而且这东西越用越大&#xff0c;删了好爽 ③重…

const XX=void0

在阅读源码中&#xff0c;经常会看到 const XXvoid0这里的 void 0其实就是 undefined&#xff0c;void 运算符总会返回一个 undefined 的结果。 那么&#xff0c;为什么要用 void 0 代替 undefined 呢&#xff1f; 总结&#xff1a; undefined 是一个「全局对象&#xff08;…

iOS——【自动引用计数】ARC规则及实现

1.3.3所有权修饰符 所有权修饰符一共有四种&#xff1a; __strong 修饰符__weak 修饰符__undafe_unretained 修饰符__autoreleasing 修饰符 __strong修饰符 _strong修饰符表示对对象的强引用&#xff0c;持有强引用的变量在超出其作用域的时候会被废弃&#xff0c;随着强引…