mybatis-plus数据批量插入
为了提高数据处理效率,大量数据需要插入数据时可以采用批量数据插入的策略提高数据插入的效率。
如下是实现方法
1、代码结构
2、实体类
- package little.tiger.one.application.testblockt.domain;
- import com.baomidou.mybatisplus.annotation.TableId;
- import com.baomidou.mybatisplus.annotation.TableName;
- import org.apache.commons.lang3.builder.ToStringBuilder;
- import org.apache.commons.lang3.builder.ToStringStyle;
- import java.util.Date;
- /**
- * <p>
- * 。
- * </p>
- *
- * @author yc
- * @since 2023-08-01
- */
- @TableName(value = "test_block_t")
- public class TestBlockT {
- private static final long serialVersionUID = 1L;
- /**
- * 。
- */
- @TableId
- private String blockId;
- /**
- * 。
- */
- private String blockName;
- public void setBlockId(String blockId) {
- this.blockId = blockId;
- }
- public String getBlockId() {
- return blockId;
- }
- public void setBlockName(String blockName) {
- this.blockName = blockName;
- }
- public String getBlockName() {
- return blockName;
- }
- @Override
- public String toString() {
- return new ToStringBuilder(this, ToStringStyle.MULTI_LINE_STYLE)
- .append("blockId", getBlockId())
- .append("blockName", getBlockName())
- .toString();
- }
- }
3、mapper
- package little.tiger.one.application.testblockt.mapper;
- import little.tiger.one.application.testblockt.domain.TestBlockT;
- import com.baomidou.mybatisplus.core.mapper.BaseMapper;
- /**
- * <p>
- * Mapper 接口。
- * </p>
- *
- * @author yc
- * @since 2023-08-01
- */
- public interface TestBlockTMapper extends BaseMapper<TestBlockT> {
- }
4、接口 尤其注意红色部分
- package little.tiger.one.application.testblockt.service;
- import com.baomidou.mybatisplus.extension.service.IService;
- import little.tiger.one.application.testblockt.domain.TestBlockT;
- import java.util.Collection;
- import java.util.List;
- import java.util.Map;
- /**
- * <p>
- * 服务类。
- * </p>
- *
- * @author yc
- * @since 2023-08-01
- */
- public interface ITestBlockTService extends IService<TestBlockT> {
- /**
- * 单记录新增。
- *
- * @param testBlockT 参数说明
- * @return status
- */
- int insert(TestBlockT testBlockT);
- boolean saveBatch(Collection<TestBlockT> entityList);
- }
5、接口实现 注意红色部分,如果是单数据源@Transactional 这么写就可以,如果是多数据源一定要指定事务例如:@Transactional(transactionManager="testTransactionManager")
- package little.tiger.one.application.testblockt.service.impl;
- import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
- import little.tiger.one.application.testblockt.domain.TestBlockT;
- import little.tiger.one.application.testblockt.mapper.TestBlockTMapper;
- import little.tiger.one.application.testblockt.service.ITestBlockTService;
- import org.springframework.stereotype.Service;
- import org.springframework.beans.factory.annotation.Autowired;
- import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
- import org.springframework.transaction.annotation.Transactional;
- import java.util.Collection;
- import java.util.List;
- import java.util.Map;
- import java.util.HashMap;
- /**
- * <p>
- * 服务实现类。
- * </p>
- *
- * @author yc
- * @since 2023-08-01
- */
- @Service
- public class TestBlockTServiceImpl extends ServiceImpl<TestBlockTMapper, TestBlockT> implements ITestBlockTService {
- @Autowired
- TestBlockTMapper testBlockTMapper;
- /**
- * 单记录新增。
- *
- * @param testBlockT 参数说明
- * @return status
- */
- @Override
- public int insert(TestBlockT testBlockT) {
- return testBlockTMapper.insert(testBlockT);
- }
- @Override
- @Transactional
- public boolean saveBatch(Collection<TestBlockT> entityList) {
- return super.saveBatch(entityList);
- }
- }
6、控制类
- package little.tiger.one.application.testblockt.controller;
- import little.tiger.one.application.testblockt.service.ITestBlockTService;
- import little.tiger.one.application.testblockt.domain.TestBlockT;
- import little.tiger.one.basemanager.page.PageUtil;
- import little.tiger.one.webbase.component.HttpStatusCode;
- import little.tiger.one.webbase.controller.BaseController;
- import little.tiger.one.webbase.pojo.AjaxResult;
- import little.tiger.one.webbase.pojo.PageDomain;
- import little.tiger.one.webbase.util.ServletUtil;
- import org.springframework.web.bind.annotation.RequestMapping;
- import org.springframework.web.bind.annotation.RestController;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.web.bind.annotation.*;
- import java.util.ArrayList;
- import java.util.List;
- import java.util.Map;
- import javax.validation.Valid;
- import javax.validation.constraints.NotNull;
- /**
- * <p>
- * 前端控制器。
- * </p>
- *
- * @author yc
- * @since 2023-08-01
- */
- @RestController
- @RequestMapping("/testblockt")
- public class TestBlockTController extends BaseController {
- @Autowired
- private ITestBlockTService testBlockTService;
- /**
- * 单记录新增。
- *
- * @param testBlockT 参数说明
- * @return AjaxResult
- */
- @PostMapping(value = "/add", headers = API_VERSION_NAME + "=v1")
- @ResponseBody
- public AjaxResult addSave(@Valid TestBlockT testBlockT) {
- List<TestBlockT> list = new ArrayList();
- TestBlockT testBlockT1 = new TestBlockT();
- testBlockT1.setBlockId("1");
- testBlockT1.setBlockName("oracle");
- list.add(testBlockT1);
- TestBlockT testBlockT2 = new TestBlockT();
- testBlockT2.setBlockId("2");
- testBlockT2.setBlockName("mysql");
- list.add(testBlockT2);
- Boolean result = testBlockTService.saveBatch(list);
- System.out.println(result);
- return AjaxResult.success(HttpStatusCode.POST_SUCCESS_CODE, "成功");
- }
- }
7、效果
调用接口日志里就是批量插入、数据库表里数据也有了
mybatis-plus数据批量插入的更多相关文章
- MyBatis 使用 foreach 批量插入
MyBatis 使用 foreach 批量插入 参考博文 老司机学习MyBatis之动态SQL使用foreach在MySQL中批量插入 使用MyBatis一次性插入多条数据时候可以使用 <for ...
- 使用事务操作SQLite数据批量插入,提高数据批量写入速度,源码讲解
SQLite数据库作为一般单机版软件的数据库,是非常优秀的,我目前单机版的软件产品线基本上全部替换Access作为优选的数据库了,在开发过程中,有时候需要批量写入数据的情况,发现传统的插入数据模式非常 ...
- C#中几种数据库的大数据批量插入
C#语言中对SqlServer.Oracle.SQLite和MySql中的数据批量插入是支持的,不过Oracle需要使用Orace.DataAccess驱动. IProvider里有一个用于实现批量插 ...
- SQL SERVER 使用BULK Insert将txt文件中的数据批量插入表中(1)
1/首先建立数据表 CREATE TABLE BasicMsg( RecvTime FLOAT NOT NULL , --接收时间,不存在时间相同的数据 AA INT NOT NULL, --24位地 ...
- C#:几种数据库的大数据批量插入
在之前只知道SqlServer支持数据批量插入,殊不知道Oracle.SQLite和MySql也是支持的,不过Oracle需要使用Orace.DataAccess驱动,今天就贴出几种数据库的批量插入解 ...
- c#数据批量插入
由于之前面试中经常被问到有关EF的数据批量插入问题,今天以Sqlserver数据库为例,对.net中处理数据批量处理的方案进行了测试对比. 1.四种测试方案 (1)普通的EF数据批量插入:即调用DbS ...
- C#:几种数据库的大数据批量插入(转)
在之前只知道SqlServer支持数据批量插入,殊不知道Oracle.SQLite和MySql也是支持的,不过Oracle需要使用Orace.DataAccess驱动,今天就贴出几种数据库的批量插入解 ...
- C#:几种数据库的大数据批量插入 - faib
在之前只知道SqlServer支持数据批量插入,殊不知道Oracle.SQLite和MySql也是支持的,不过Oracle需要使用Orace.DataAccess驱动,今天就贴出几种数据库的批量插入解 ...
- PHP如何将多维数组中的数据批量插入数据库?
PHP将多维数组中的数据批量插入到数据库中,顾名思义,需要用循环来插入. 1.循环insert into 语句,逐渐查询 <?php /* www.qSyz.net */ @mysql_conn ...
- c#几种数据库的大数据批量插入(SqlServer、Oracle、SQLite和MySql)
这篇文章主要介绍了c#几种数据库的大数据批量插入(SqlServer.Oracle.SQLite和MySql),需要的朋友可以了解一下. 在之前只知道SqlServer支持数据批量插入,殊不知道Ora ...
随机推荐
- 【Codeforces Global Round 12】 C2 - Errich-Tac-Toe题解(思维)
题面 题目要求不能有有三个连续相同的'X'或'O',注意到这样的连续串它们的横纵坐标之和是连续变化的,考虑将它们按照横纵坐标之和对 \(3\)的模值分组,因为这样分组后相邻的三个相同字符就被分到了三个 ...
- net8获取泛微token以及访问api示例
工作中涉及到调用泛微的场景,官方的示例又臭又长,抽空用NET8简化了写法,为了简化http访问,用了Flurl.Http这个库.在座各位大佬,我们直接就看代码了 using System.Secu ...
- redis集群搭建注意事项
官方教程:https://redis.io/docs/management/scaling/ 其他参考: https://note.youdao.com/ynoteshare/index.html?i ...
- python tkinter 使用(八)
python tkinter 使用(八) 本文主要讲下tkinter库中的其他的一些模块,如simpleDialog,scrollerText等. 1: simpleDialog simpledial ...
- 【scikit-learn基础】--『监督学习』之 LASSO回归
LASSO(Least Absolute Shrinkage and Selection Operator)回归模型一般都是用英文缩写表示,硬要翻译的话,可翻译为 最小绝对收缩和选择算子. 它是一种线 ...
- 【scikit-learn基础】--『监督学习』之 K-近邻分类
KNN(K-近邻),全称K-Nearest Neighbors,是一种常用的分类算法.KNN算法的历史可以追溯到1957年,当时Cover和Hart提出了"最近邻分类"的概念.但是 ...
- Pikachu漏洞靶场 RCE(远程命令执行/代码执行)
RCE 文章目录 RCE 概述 exec "ping" exec "eval" 概述 RCE(remote command/code execute),远程命令 ...
- Golang实现JAVA虚拟机-指令集和解释器
原文链接:https://gaoyubo.cn/blogs/f57f32cf.html 前置 Golang实现JAVA虚拟机-解析class文件 Golang实现JAVA虚拟机-运行时数据区 一.字节 ...
- Sequelize的简单连接和使用
Sequelize是一个基于Node.js的ORM框架 特点: 1.支持多种数据库:Sequelize支持多种关系型数据库,包括MySQL.PostgreSQL.SQLite和MSSQL等,适用于需要 ...
- 微信小程序中业务域名的配置
需要配置业务域名,需要先将域名http转https 1,首先在该微信小程序的公众号平台中下载 业务域名的证书 2,将下载的证书放进nginx的根目录 3,在nginx中 (root为.txt的地址)