mybatis处理批量数据插入怎么处理效率最高
mybatis批量插入数据三种方式:1.代码for循环,每次插入一条数据2.动态拼接sql, insertinto() values ()();3.使用mybatis的BatchExecutor;测试数量5w条;方案1: new5w个对象放入list;然后for 循环插入 耗时大概23s方案2: new1k 个对象放入一个list, 然后list 放入map; 一共new 5w 对象;for 循环
·
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; 不过这个值可以设置
方案三: 速度适中,缺点是在事物没有提交前是获取不到插入数据返回的主键的
更多推荐
已为社区贡献1条内容
所有评论(0)