1. saveBatch能否提高插入的效率?
先说结论,saveBatch()方法也是一条一条的插入,也就是说它会产生多条insert语句,而不是一条insert语句,所以它不是真正的批量插入,更不能提高插入效率。
看看代码就全明白了
从代码看,循环一条一条的插入,每次都是一个sqlSession.insert()
因此,saveBatch()并不能提高插入的效率。想要实现一条insert语句批量插入的效果,还得自己写insert语句
2. 如果insert批量插入的时候失败了怎么办?
插入数据的时候,经常会遇到非空校验、唯一约束等等,如果不满足的话就插入失败了
当我们使用insert批量插入的时候,如果中间有一条或多条数据插入失败了,此时这一批次的所有数据都不会插入成功。因为这是一条insert语句,它是一个原子操作,要么所有的都插入成功,要么都失败。
如果希望忽略那些插入失败的数据,可以加ignore关键字,例如:
除了可以指定IGNORE关键字以外,还可以加上 ON DUPLICATE KEY UPDATE 表示重复的话执行update语句
详见 https://dev.mysql.com/doc/refman/8.0/en/insert.html
3. 批量插入的数据条数有没有限制
条数没有限制,但是发送给MySQL服务器的SQL语句大小有限制,默认是4M。因此,一次批量插多少条取决于每一条数据有多大。