批量向MySQL导入数据
- 直接导入
- 使用存储过程循环拼接
- 使用load data infile
- 修改ENGINE=InnoDB为MyISAM(v5.1之前是MyISAM,之后是InnoDB)
- 减少IO次数
- SQL写法优化(一条SQL语句插入多条数据)
- 合理设置批量大小(在事务中进行插入处理,不要一条数据提交一次,肯定要分批处理)
- 尽量顺序插入(减少索引的维护压力)
- 合并事务+事务+有序数据的优化插入方式
- 注意SQL批量插入的大小必须合理
- 事务执行时间不要太长
- 合理设置MySQL相应配置参数,增加缓存或减少不必要日志磁盘读写
合并SQL语句
一条SQL插入一条数据
insert into tb1(id,name,age,sex) values(1,'khue',25,'m');
insert into tb1(id,name,age,sex) values(2,'green',24,'w');
一条SQL插入多条数据
insert into tb1