问题:
插入大随机数作为键时在表中,MySQL InnoDB 的插入速度比 MyISAM 慢得多。例如,在一个 1000 万行的表中插入 100 万行,使用 MyISAM 需要 6 秒,而使用 InnoDB 需要 3433 秒。
原因:
主要原因这种差距在于InnoDB的事务支持机制。与 MyISAM 直接将数据存储在磁盘上而无需任何中间缓冲不同,InnoDB 为每个插入语句执行日志刷新到磁盘。这种每条语句提交的行为会显着影响性能。
解决方案:
为了优化 InnoDB 插入速度,建议使用显式事务。通过将插入语句封装在事务中,您可以将提交操作推迟到所有语句都执行完毕。这种方法极大地减少了所需的磁盘刷新次数,从而提高了插入速度。
要应用此解决方案,请在插入循环之前和之后执行以下命令:
插入之前循环:
START TRANSACTION;
插入后循环:
COMMIT;
通过实施此技术,您可以显着加速 InnoDB 插入性能并获得与 MyISAM 相当的速度,同时仍然受益于 InnoDB 的事务支持和数据完整性功能。
以上是为什么 MySQL InnoDB 插入比 MyISAM 插入慢很多?的详细内容。更多信息请关注PHP中文网其他相关文章!