我需要导出一个没有外键的大型数据库。执行此操作的命令是什么?
这是我尝试过的,但我知道这是不正确的。
mysqldump -u root -p DBNAME SET FOREIGN_KEY_CHECKS = 0; | gzip > database.sql.gzip
您可以--init-command
在每个会话的基础上使用该标志:
mysql --init-command="SET SESSION FOREIGN_KEY_CHECKS=0;" ... < dump.sql
从这个 SO 线程:
你能自动创建一个不强制外键约束的 mysqldump 文件吗?
MySQL 5.0.51 中包含的 mysqldump 命令(根据 4.1.1 以来的更改日志版本)确实关闭了外键检查。默认情况下,mysqldump 在转储文件的顶部包含以下行:
/*!40014 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0 */;
/*!40014 ... */ 语法是一个条件注释,将在 MySQL 4.0.14 及更高版本上执行。旧的外键检查设置在转储文件的末尾恢复:
/*!40014 SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS */;
这很难看,但我最终只是修改了架构文件以删除外键。
mysqldump -uuser -ppassword --no-data dbname | sed '$!N;s/^\(\s*[^C].*\),\n\s*CONSTRAINT.*FOREIGN KEY.*$/\1/;P;D' | grep -v 'FOREIGN KEY' > dbname_schema_no_fk.sql
sed
查找外键约束声明之前的行,并用它们自己替换这些行,减去尾随的逗号。 grep
排除外键约束。
mysqldump -uuser -ppassword --no-create-info dbname > dbname_data.sql
$ mysql -uuser -ppassword
> create database foo
> use foo
> source dbname_schema_no_fk.sql
> source dbname_data.sql
使用 mysqldump Ver 10.13 Distrib 5.6.32-78.1 测试,适用于 Linux (x86_64)。