Windows导入大型sql文件到mysql

Windows导入大型sql文件到mysql

因需求,有个大小约9GB的.sql文件需要导入到mysql数据库,正好是周末也不急,为了省事就用了可视化工具datagrip运行了sql文件,结果睡一觉起来发现还没导入完成,给我震惊的。

后面还是准备用命令来导入

觉得比较实用,分享一下

因为这个文件比较大,所以前期需要做一些准备工作,首先是找到mysql的配置文件:my.ini

其次是找到mysql的安装地址,Windows上找到这两个比较简单
首先:

打开服务,cmd>servermanager.msc

找到mysql服务,可以右键>属性查看

一般都是默认的,如果你没改过地址的话

bash 复制代码
"C:\Program Files\MySQL\MySQL Server 8.0\bin\mysqld.exe" --defaults-file="C:\ProgramData\MySQL\MySQL Server 8.0\my.ini" MySQL80

打开配置文件修改参数,my.ini,记得保存

bash 复制代码
# 最大数据包大小(必须大于 SQL 文件中最大语句,9GB 文件设 2G)
max_allowed_packet = 2G

# InnoDB 缓冲池(根据内存调整:8GB 内存设 4G,16GB 设 8G,32GB 设 16G)
innodb_buffer_pool_size = 6G  # 请按你的内存修改,例如 8GB 内存改为 4G

# 日志文件大小(减少切换频率)
innodb_log_file_size = 1G

# 临时关闭实时刷盘(导入后改回 1)
innodb_flush_log_at_trx_commit = 0

在Windows服务页面重启MySQL服务

然后在MySQL的安装目录下执行命令

第一步:打开 "加速开关"(必须先做)
(保持这个窗口打开,别关)!!!

bash 复制代码
mysql -uroot -p

继续输入

bash 复制代码
USE 数据库名; -- 切换到你的数据库
SET autocommit=0;
SET foreign_key_checks=0; -- 禁用外键检查(提速核心)
SET unique_checks=0;      -- 禁用唯一索引检查(避免重复校验)
SET sql_log_bin=0;        -- 临时禁用二进制日志(减少写入开销)

再开一个 "管理员命令提示符"依旧是在这安装目录下执行(新窗口,别关第一个)

bash 复制代码
mysql -uroot -p --default-character-set=utf8mb4 l0862wms < "D:\backup\你的9GB文件.sql"

按回车后,输入 MySQL 密码,回车就开始导入了(命令行窗口会 "卡住",这是正常的,说明在执行)。

导入期间注意事项

别关闭两个命令行窗口,也别让电脑休眠(可以把屏幕关掉,不影响后台执行)。

可以偶尔打开任务管理器,看 mysqld.exe 的 "磁盘 IO 占用"(有波动说明在正常导入,没波动可能是卡在某条语句,耐心等几分钟再看)。

可以看到正在积极的执行写入

相关推荐
czlczl200209258 分钟前
SpringBoot实践:从验证码到业务接口的完整交互生命周期
java·spring boot·redis·后端·mysql·spring
爱好读书41 分钟前
AI生成ER图|SQL生成ER图
数据库·人工智能·sql·毕业设计·课程设计
最贪吃的虎1 小时前
MySQL调优 一:慢SQL日志
运维·数据库·后端·mysql
最贪吃的虎1 小时前
MySQL调优 二:explain参数详解+索引优化实战
数据库·mysql
小丁努力不焦虑1 小时前
mysql八股文
数据库·mysql
rannn_1111 小时前
【SQL题解】力扣高频 SQL 50题|DAY2+3
数据库·后端·sql·leetcode
l1t1 小时前
DeepSeek对Oracle 数据库新特性 SQL 宏的总结
数据库·人工智能·sql·oracle
cnxy1881 小时前
MySQL地理空间数据完整使用指南
android·数据库·mysql
鲸说MySQL1 小时前
【MySQL事务(一)事务的操作流程】
数据库·mysql
一个天蝎座 白勺 程序猿1 小时前
Apache IoTDB(12):深度解析时序数据聚合的GROUP BY与HAVING子句
数据库·sql·apache·iotdb