mysql批量插入数据时一般有如下两种方法:
(1)一次插入一条;当数据多时,循环执行该SQL语句;
INSERT INTO example (example_id, name, value, other_value) VALUES (100, 'Name 1', 'Value 1', 'Other 1');
(2)一次插入多条数据;
INSERT INTO example (example_id, name, value, other_value) VALUES (100, 'Name 1', 'Value 1', 'Other 1'), (101, 'Name 2', 'Value 2', 'Other 2'), (102, 'Name 3', 'Value 3', 'Other 3'), (103, 'Name 4', 'Value 4', 'Other 4');
由于第一种方法中每一条记录的插入都会被mysql看做一次事务,所以会明显慢于第二种。我们可以将整个循环插入作为一个事务提交,这样能够大大提高它的插入速度。
第二种方法实际上就是对sql语句的拼接,将多条记录放在values后面。需要注意的时,它会出现sql语句过长的隐患,当values后面的记录比较多时。sql语句过长时,则需要对mysql进行配置。