Mybatis Plus批量插入数据到MySQL中

数据库 MySQL
SQL语句的长度受MySQL服务端的max_allowed_packet参数限制,默认为1M,如果拼接的字符串过长则会报错。可以进来减少批量提交的记录,或者是调整max_allowed_packet参数的大小。

​作为CRUD程序员,大部分Java开发者应该都在用Mybatis Plus来操作数据库。但是BaseMapper默认仅提供了int insert(T entity)这个单条插入的方法。那么我们想批量插入数据该怎么办呢?

在以前用Mybatis的时候,我们会在Mapper.xml里面去写foreach循环:

1
2
3
4
5
6
7
8
insert into user (user_name,create_time)
values

<foreach item="item" index="index" collection="list" separator=",">

(#{list.userName},now())

</foreach>

如果批量的实体对象较多的话,我们就会写很多这样的Mapper,如果表字段较多,这工作量的也不小的,当然,如果你用了代码生成工具,那就当我没说。Mybatis Plus作为Mybatis的增强版,也为我们考虑到了这个问题。使用Mybatis Plus批量插入数据有两种方式,第一种是Service层继承IService,第二种便是insertBatchSomeColumn。先来看看IService的方式

  • 新建Mapper继承BaseMapper<T>public interface UserMapper extends BaseMapper<UserDO> {}
  • 新建一个Service接口,继承IService<T>public interface UserService extends IService<UserDO> { void batchAddUser();}
  • 新建一个Service实现类,继承ServiceImpl<M,T>public class UserServiceImpl extends ServiceImpl<UserMapper,UserDO> implements UserService { @Autowired private UserMapper userMapper; @Override public void batchAddUser() { List<UserDO> userDOList=new ArrayList<>(); UserDO user1=new UserDO(); user1.setAge(99); user1.setName("99_1"); userDOList.add(user1); UserDO user2=new UserDO(); user2.setAge(999); user2.setName("999_1"); userDOList.add(user2); this.saveBatch(userDOList,2); }}

这种方式,会生成多条INSERT语句一条条执行,然后按设置的batchSize来提交事务。

我们再来看看insertBatchSomeColumn是怎么做的呢。1.新建一个InsertBatchInjector类来扩展DefaultSqlInjector

1
2
3
4
5
6
7
8
9
@Component
public class InsertBatchInjector extends DefaultSqlInjector {
@Override
public List<AbstractMethod> getMethodList(Class<?> mapperClass, TableInfo tableInfo) {
List<AbstractMethod> methodList = super.getMethodList(mapperClass,tableInfo);
methodList.add(new InsertBatchSomeColumn());
return methodList;
}
}

2.新建一个Mapper接口,继承BaseMapper<T>并添加insertBatchSomeColumn方法,

1
2
3
4
@Mapper
public interface UserMapper extends BaseMapper<UserDO> {
int insertBatchSomeColumn(List<UserDO> userDOList);
}

3.在要批量写的地方直接调用该Mapper的insertBatchSomeColumn即可

1
2
3
4
5
6
7
8
9
10
11
12
public void batchAddUser() {
List<UserDO> userDOList=new ArrayList<>();
UserDO user1=new UserDO();
user1.setAge(99);
user1.setName("99_1");
userDOList.add(user1);
UserDO user2=new UserDO();
user2.setAge(999);
user2.setName("999_1");
userDOList.add(user2);
userMapper.insertBatchSomeColumn(userDOList);
}

这种方式则是拼接成一条SQL,一次性提交到数据库执行

这里,SQL语句的长度受MySQL服务端的max_allowed_packet参数限制,默认为1M,如果拼接的字符串过长则会报错。可以进来减少批量提交的记录,或者是调整max_allowed_packet参数的大小。除了受到max_allowed_packet的影响,innodb_buffer_pool_size的大小也会影响批量的记录数大小,innodb_buffer_pool_size的默认值为128M,我们可以根据情况适当调整,合理地配置innodb_buffer_pool_size参数,可以提高MySQL的读写性能。

责任编辑:武晓燕 来源: 今日头条
相关推荐

2021-09-27 07:56:41

MyBatis Plu数据库批量插入

2023-06-07 08:00:00

MySQL批量插入

2024-07-31 09:56:20

2022-12-29 08:49:40

SpringBootExcel

2021-04-08 10:55:53

MySQL数据库代码

2023-12-30 20:04:51

MyBatis框架数据

2021-10-09 06:59:36

技术MyBatis数据

2022-09-23 09:44:17

MyBatisforeach

2013-04-01 15:03:58

Android开发Android批量插入

2013-09-22 10:25:23

MySQLSQL性能优化

2020-11-23 10:50:27

MySQLSQL数据库

2021-10-18 07:58:33

MyBatis Plu数据库批量插入

2009-07-20 17:03:55

批量插入数据ASP.NET

2021-11-19 11:50:48

MyBatisforeachJava

2011-08-04 18:00:47

SQLite数据库批量数据

2021-02-01 00:04:13

Dictionary数据批量

2024-10-22 08:47:03

2023-06-07 08:08:37

MybatisSpringBoot

2009-08-11 14:51:47

C#读取Excel中数

2010-09-03 11:47:38

SQL删除
点赞
收藏

51CTO技术栈公众号