JAVA批量新增、批量修改

JAVA批量新增、批量修改

      • 若数据量非常大,可以把List拆成多份,每份1000条数据。
      • NetPointDTO
      • 批量新增SQL.xml
      • 批量修改SQL.xml

若数据量非常大,可以把List拆成多份,每份1000条数据。

import cn.hutool.core.collection.ListUtil;
import cn.hutool.core.util.StrUtil;
import cn.路劲.NetPointDTO;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Service;import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;@Slf4j
@Service
public class NetPointServiceImpl implements NetPointService {/*** 批量新增*/@Overridepublic boolean add(List<NetPointDTO> dataList) {//数据里的 编码 查重String netPointCode = dataList.stream().collect(Collectors.groupingBy(NetPointDTO::getNetPointCode, Collectors.counting())).entrySet().stream().filter(e -> e.getValue() > 1L).map(Map.Entry::getKey).collect(Collectors.joining("、"));if (StrUtil.isNotBlank(netPointCode)){throw new RuntimeException("网点编码 "+ netPointCode + " 重复");}//切分List, 此方法返回的是原List的视图,也就是说原List有变更,切分后的结果也会变更List<List<NetPointDTO>> partition = ListUtil.partition(dataList, 1000);Integer n = 0;for (List<NetPointDTO> list : partition){//Mapper 很简单,就不赘述了n = 执行批量新增的Mapper.addBatch(list);}return n > 0;}
}

NetPointDTO

import io.swagger.annotations.ApiModelProperty;
import lombok.Data;import javax.validation.constraints.NotBlank;
import javax.validation.constraints.Size;@Data
public class NetPointDTO {@ApiModelProperty(value = "网点信息编码", example = "企业网点编码", required = true)@NotBlank(message = "网点信息编码, 值不能为空")@Size(max = 50, message = "网点信息编码,最大长度 50位")private String netPointCode;;@ApiModelProperty(value = "网点名称", example = "网点名称", required = true)@NotBlank(message = "网点名称,值不能为空")@Size(max = 50, message = "网点名称,值长度 不能超过 50位")private String netPointName;@ApiModelProperty(value = "点坐标", example = "39.625934 118.232805", required = true)@NotBlank(message = "点坐标, 不能为空")private String point;@ApiModelProperty(value = "办公地点", example = "办公地址", required = true)@NotBlank(message = "办公地址, 不能为空")@Size(max = 100, message = "办公地点,值长度 不能超过 100位")private String officeAddress;
}

批量新增SQL.xml

useGeneratedKeys=“true” keyProperty=“id”
useGeneratedKeys设置为 true 时,
表示如果插入的表id以自增列为主键,则允许 JDBC 支持自动生成主键,并可将自动生成的主键id返回。
下边这种写法,实际上是通过循环,数据也是一条一条的插入的,好处是每条数据都有判断是否为null。

<insert id="addBatch" parameterType="java.util.List" keyProperty="id" useGeneratedKeys="true"><foreach collection="list" item="e" index="index" separator=";">insert into NET_POINT<trim prefix="(" suffix=")" suffixOverrides=","><if test="e.netPointCode != null"> net_point_code, </if><if test="e.netPointName != null"> NET_POINT_NAME, </if><if test="e.point != null"> POINT, </if><if test="e.officeAddress != null"> OFFICE_ADDRESS, </if>CREATE_TIME</trim>values<trim prefix="(" suffix=")" suffixOverrides=","><if test="e.netPointCode != null"> #{e.netPointCode}, </if><if test="e.netPointName != null"> #{e.netPointName}, </if><if test="e.point != null"> dmgeo.ST_PointFromText(CONCAT('point(', #{e.point}, ')'), 0), </if><if test="e.officeAddress != null"> #{e.officeAddress}, </if>now()</trim></foreach>
</insert>

sql中point点坐标,前边的函数 是达梦数据库的,
MySQL数据库的函数为 ST_GEOMFROMTEXT(CONCAT(‘POINT(’, #{point}, ‘)’))
若直接批量新增,可以这样写

<insert id="saveBatch">insert into NET_POINT(net_point_code, NET_POINT_NAME, POINT, CREATE_TIME)values<foreach collection="list" item="e" separator=",">( 	#{e.netPointCode}, #{e.netPointName},dmgeo.ST_PointFromText(CONCAT('point(', #{e.point}, ')'), 0),NOW())</foreach>
</insert>

批量修改SQL.xml

<update id="updateBatch" parameterType="java.util.List"><foreach collection="list" item="e" index="index" open="" close="" separator=";">UPDATE NET_POINT<set>update_time = NOW(),<if test="e.netPointName != null and e.netPointName != ''">NET_POINT_NAME = #{e.netPointName},</if><if test="e.point != null and e.point != ''">point = dmgeo.ST_PointFromText(CONCAT('point(', #{e.point}, ')'), 0),</if><if test="e.officeAddress != null and e.officeAddress != ''">OFFICE_ADDRESS = #{e.officeAddress},</if></set>WHERE NET_POINT_CODE = #{e.netPointCode}</foreach>
</update>

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

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

相关文章

Unity Enum位掩码(BitMask)的运用

Unity Enum位掩码&#xff08;BitMask&#xff09;的运用 前言项目使用场景代码编写定义技能枚举角色类学习技能检查技能 添加并设置脚本运行效果总结 感谢 前言 在Unity游戏开发中&#xff0c;我们经常会面临需要对一组相关的状态进行管理的情况。Enum位掩码是一种有效的方法…

Spring 与 SpringBoot:一窥两者的奥秘与差异

随着 Java 开发领域的不断演进&#xff0c;Spring 框架已经成为了许多企业级应用的首选。然而&#xff0c;近年来&#xff0c;随着 SpringBoot 的兴起&#xff0c;许多开发者开始对其产生了浓厚的兴趣。尽管 SpringBoot 和 Spring 都来自于同一个家族&#xff0c;并且都是为了简…

【LeetCode】150. 逆波兰表达式求值(ASCII码)

今日学习的文章链接和视频链接 leetcode题目地址&#xff1a;150. 逆波兰表达式求值 代码随想录题解地址&#xff1a;代码随想录 题目简介 即将后缀表达式转换成中缀表达式并计算。 给你一个字符串数组 tokens &#xff0c;表示一个根据 逆波兰表示法 表示的算术表达式。 …

【编译原理】期末预习PPT前四章笔记II

看了看学校的ppt&#xff0c;记的比较随意O.o 因为我的考试范围里边没有简答所以概念什么的没怎么记 没有简答只有选择真是太好了嘿嘿嘿 目录 I. 概述&#xff08;好多字。。&#xff09; 一、高级语言的分类 1、体裁 2、执行方式 二、各种语言的执行方式 三、编译程序…

读算法霸权笔记11_微目标

1. 脸书 1.1. 一份请愿书属于脸书了&#xff0c;而社交网络的算法会对如何最大限度地利用这份请愿书做出判断 1.1.1. 脸书的算法在决定谁能看到我的请愿书时会把所有因素都考虑在内 1.2. 通过改变信息推送的方式&#xff0c;脸书研究了我们…

智能分析网关V4智慧港口码头可视化视频智能监管方案

一、需求背景 近年来&#xff0c;水利港口码头正在进行智能化建设&#xff0c;现场管理已经是重中之重。港口作为货物、集装箱堆放及中转机构&#xff0c;具有昼夜不歇、天气多变、环境恶劣等特性&#xff0c;安全保卫工作显得更加重要。港口码头的巡检现场如何高效、快捷地对…

16.Linux Bash Shell通过`read`命令读取用户输入

文章目录 Linux Shell获取用户输入处理简单输入控制等待隐藏输入从文件中读取 欢迎访问个人网络日志&#x1f339;&#x1f339;知行空间&#x1f339;&#x1f339; Linux Shell获取用户输入 处理简单输入 shell与用户交互式输入使用的是read命令&#xff0c;一个简单的例子…

nuxt3 服务端请求其他接口犯的问题与解决

目的 老项目迁移到 nuxt3&#xff0c;为了减少代码修改量&#xff0c;打算封装一个在服务端运行的请求函数&#xff0c;用于在服务端渲染页面的同时&#xff0c;将接口数据请求回来一起返回给客户端 在服务端请求接口并渲染到页面上、在客户端不请求该接口&#xff0c;但需要能…

5G工业物联网网关:连接未来的智能工业

在当今数字化时代&#xff0c;工业物联网正迅速崛起&#xff0c;并引领着全球工业的数字转型。而5G工业物联网网关作为实现IIoT的关键基础设施&#xff0c;在连接未来的智能工业中发挥着举足轻重的作用。 什么是5G工业物联网网关 5G工业物联网网关是连接工业设备和5G网络的关键…

(湖科大教书匠)计算机网络微课堂(下)

第四章、网络层 网络层概述 网络层主要任务是实习网络互连&#xff0c;进而实现数据包在各网络之间的传输 因特网使用TCP/IP协议栈 由于TCP/IP协议栈的网络层使用网际协议IP&#xff0c;是整个协议栈的核心协议&#xff0c;因此TCP/IP协议栈的网络层常称为网际层 网络层提供…

SpringBoot整合sentinel

1、引入依赖 <dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-sentinel</artifactId> </dependency> 2、 配置文件添加 spring:cloud:sentinel:transport:dashboard: ip:8858 项目重启&#x…

15.三数之和(双指针,C解答附详细分析)

题目描述&#xff1a; 给你一个整数数组 nums &#xff0c;判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i ! j、i ! k 且 j ! k &#xff0c;同时还满足 nums[i] nums[j] nums[k] 0 。请 你返回所有和为 0 且不重复的三元组。 注意&#xff1a;答案中不可以包含…

暴力破解的基础知识和Burpsuite基础知识

定义 暴力破解 (Brute Force)也称为字典攻击&#xff0c;通常被用于攻击网站的用户账户名/密码 使用自动化脚本以枚举的方式尝试所有可能的用户名或密码组合。通过攻击用户的账户名和密码&#xff0c;窃取用户个人信息或获取网站管理权限等。 暴力破解攻击产生原因 1、用户口…

【mujoco】Ubuntu20.04中解决mujoco报错raise error.MujocoDependencyError

【mujoco】Ubuntu20.04中解决mujoco报错raise error.MujocoDependencyError 文章目录 【mujoco】Ubuntu20.04中解决mujoco报错raise error.MujocoDependencyError1. 报错的具体情况2. 解决过程3. 其他问题3.1 ModuleNotFoundError: No module named OpenGL3.2 ModuleNotFoundEr…

AUTOSAR汽车电子嵌入式编程精讲300篇-面向不平衡样本的车载网入侵检测系统 设计与实现 (续)

目录 3.2 传统CANTransfer模型原理 3.2.1 传统CANTransfer模型结构及特点 3.2.2 二维空间变换分析

nc的用法

nc的用法 测试udp端口是否可用 如果是测试某个IP地址地址是否可以访问&#xff0c;通常会使用 ping 命令&#xff0c;执行之后如果可以到达就会得到数据反馈&#xff1a; alberthome-pc:~$ ping 82.156.125.169 PING 82.156.125.169 (82.156.125.169) 56(84) bytes of data.…

第84讲:基于各种场景使用mysqldump逻辑备份数据库

文章目录 1.mysqldump备份工具的语法格式2.使用mysqldump进行全库备份3.备份单个库或者多个库的数据4.备份某个库下的单表或者多表的数据5.mysqldump备份数据库时必加的一些参数5.1.基本参数5.2.核心参数 6.mysqldump备份数据库时的一些其他参数 1.mysqldump备份工具的语法格式…

Docker Compose--部署SpringBoot项目--实战

原文网址&#xff1a;Docker Compose--部署SpringBoot项目--实战-CSDN博客 简介 本文用实战介绍Docker Compose部署SpringBoot项目。 1.创建SpringBoot项目 Controller package com.knife.example.controller;import io.swagger.annotations.Api; import io.swagger.annot…

HTTP基础知识总结

目录 一、什么是HTTP&#xff1f; 二、与HTTP有关的协议 三、HTTP请求特征 四、HTTP组成格式 五、HTTP标头 1.通用标头 2.实体标头 3.请求标头 4.响应标头 六、HTTP状态码分类 我们在日常测试过程中&#xff0c;也可以通过浏览器F12简单定位是前端问题还是后端问题&a…

Linux mrd命令教程:如何删除MS-DOS文件系统中的目录(附实例教程和注意事项)

Linux mrd命令介绍 mrd命令是用于删除MS-DOS文件系统中的目录。这是mtools工具指令&#xff0c;模拟MS-DOS的rd指令&#xff0c;可以删除MS-DOS的目录。 Linux mrd命令适用的Linux版本 mrd命令在所有主流的Linux发行版中都可以使用&#xff0c;包括但不限于Ubuntu&#xff0…