使用mysqldump迁移MySQL数据需先在源服务器导出:mysqldump -u root -p –single-transaction –routines –triggers mydatabase > mydb_backup.sql,再通过scp等工具传输文件至目标服务器,导入前创建数据库并确保字符集一致,最后执行:mysql -u root -p mydatabase < /tmp/mydatabase.sql,大库建议压缩传输并关闭外键检查以提升效率。

使用 mysqldump 迁移 MySQL 数据是一种常见且高效的方法,适用于数据库备份、迁移或复制。整个过程主要包括导出数据和导入数据两个步骤。
1. 使用 mysqldump 导出数据
在源服务器上执行 mysqldump 命令将数据库内容导出为 SQL 文件。
基本语法:
-
mysqldump -u [用户名] -p[密码] [数据库名] > [文件路径]
示例:
-
mysqldump -u root -p mydatabase > /backup/mydatabase.sql
执行后会提示输入密码(推荐方式),避免在命令行中明文暴露密码。
如果需要导出多个数据库或所有数据库:
- 导出多个库:
mysqldump -u root -p --databases db1 db2 > backup.sql
- 导出所有数据库:
mysqldump -u root -p --all-databases > alldb.sql
若包含存储过程、触发器等,可添加参数:
-
--routines
:包含函数和存储过程
-
--triggers
:包含触发器(默认启用)
-
--single-transaction
:适用于 InnoDB,保证一致性而不锁表
完整示例:
-
mysqldump -u root -p --single-transaction --routines --triggers mydatabase > mydb_backup.sql
2. 将导出文件传输到目标服务器
使用 scp、rsync 或U盘等方式将 .sql 文件复制到目标机器。
例如使用 scp:
-
scp /backup/mydatabase.sql user@target-server:/tmp/
3. 在目标服务器导入数据
先确保目标 MySQL 服务运行,并创建对应数据库(如不存在)。
-
mysql -u root -p -e "CREATE DATABASE IF NOT EXISTS mydatabase;"
然后导入 SQL 文件:
-
mysql -u root -p mydatabase < /tmp/mydatabase.sql
导入过程中不显示进度,大文件需耐心等待。可通过查看是否返回命令提示符判断完成。
4. 注意事项与优化建议
- 确保目标 MySQL 版本兼容,避免因版本差异导致语法错误
- 大数据库建议压缩传输:
导出时:mysqldump ... | gzip > db.sql.gz
导入时:
gunzip < db.sql.gz | mysql -u root -p dbname
- 导入前关闭外键检查可提升速度(导入完成后开启):
SET foreign_key_checks = 0;
(放在SQL文件开头)
SET foreign_key_checks = 1;
(结尾)
- 网络不稳定时建议使用 pv 工具监控进度:
pv mydb.sql | mysql -u root -p mydatabase
基本上就这些。操作不复杂但容易忽略权限和字符集问题,建议导出时明确指定 –default-character-set,保持源和目标一致。


