@hengbao
2018-06-04T03:27:59.000000Z
字数 757
阅读 1273
Mybatis
@Testpublic void testInsertBatch() throws Exception {long start = System.currentTimeMillis();List<User> list = new ArrayList<>();User user;for (int i = 0; i < 10000; i++) {user = new User();user.setId("test" + i);user.setName("name" + i);user.setDelFlag("0");list.add(user);}userService.insertBatch(list);long end = System.currentTimeMillis();System.out.println("---------------" + (start - end) + "---------------");}
<insert id="insertBatch">INSERT INTO t_user(id, name, del_flag)VALUES<foreach collection ="list" item="user" separator =",">(#{user.id}, #{user.name}, #{user.delFlag})</foreach ></insert>
特别注意:mysql默认接受sql的大小是1048576(1M),若数据量超过1M会报异常:(可通过调整MySQL安装目录下的my.ini文件中[mysqld]段的"max_allowed_packet = 1M")
这里需要注意的是,collection 属性必须指明,对应List、Array、Map都有具体规则,可以参考官方文档