MyBatis原生批量插入的坑与解决方案

// 最大循环次数

private static final int MAXCOUNT = 100000;

@Autowired

private UserServiceImpl userService;

/**

  • 原生自己拼接 SQL,批量插入

*/

@Test

void saveBatchByNative() {

long stime = System.currentTimeMillis(); // 统计开始时间

List list = new ArrayList<>();

for (int i = 0; i < MAXCOUNT; i++) {

User user = new User();

user.setName(“test:” + i);

user.setPassword(“123456”);

list.add(user);

}

// 批量插入

userService.saveBatchByNative(list);

long etime = System.currentTimeMillis(); // 统计结束时间

System.out.println(“执行时间:” + (etime - stime));

}

}

核心文件 UserMapper.xml 中的实现代码如下:

<?xml version="1.0" encoding="UTF-8"?>

INSERT INTO USER(NAME,PASSWORD) VALUES

  • 23
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值