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

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。

更多推荐