mybatis批量插入数据三种方式:

1.代码for 循环,每次插入一条数据
2.动态拼接sql , insert into () values ()();
3.使用mybatis 的BatchExecutor;
测试数量5w条;
方案1: new 5w 个对象放入list;然后for 循环插入 耗时大概23s
方案2: new1k 个对象放入一个list, 然后list 放入map; 一共new 5w 对象; for 循环map ,递归循环list, 耗时2.3s
方案3: new 5w 对象, 放入list; for循环集合; 使用BatchExecutor插入对象 耗时8.3s
经过对比: 方案一耗时最多;
方案2:速度最快, 缺点是需要把握每次插入的调试, 默认传入参数长度是1M; 不过这个值可以设置
方案三: 速度适中,缺点是在事物没有提交前是获取不到插入数据返回的主键的

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐