随着数据体量不断增长,大型 SQL 文件的导入需求逐渐增多。近期我在本地 Windows 10(内存64GB)环境下,需要将一个 2.73GB 的 .sql 文件导入 MySQL 8.0.32 数据库。很多人都觉得 Navicat 无法应对超大 SQL,实际只要合理调整数据库参数,在高配置PC下,Navicat 也能高效完成导入。本文记录我的实战方法与参数配置,希望为同样需求的同行提供参考。
mysql -uroot -p db名 < 文件.sql
可能遇到 server has gone away
, packet too large
等问题;经过多次尝试,我总结出能让 Navicat 顺利导入超大 SQL 文件的关键做法,就是调整 MySQL 的内存与包相关参数。
my.ini
,并重启MySQL服务):innodb_buffer_pool_size=16G
innodb_log_buffer_size=1G
innodb_log_file_size=1024M
innodb_flush_log_at_trx_commit=2
max_allowed_packet=1024M
my.ini
),并重启 MySQL 服务
索引这些参数必须生效。
SHOW VARIABLES LIKE 'max_allowed_packet';
等检查参数本次实战经历证明,只要把握MySQL几个关键参数,再配合64GB内存等硬件优势,即便使用Navicat也能几分钟内流畅导入大体积SQL文件。而“max_allowed_packet”等参数正是成功的关键。希望本文能帮助到面临同类大SQL导入挑战的朋友