9

我需要导出一个没有外键的大型数据库。执行此操作的命令是什么?

这是我尝试过的,但我知道这是不正确的。

mysqldump -u root -p DBNAME SET FOREIGN_KEY_CHECKS = 0; | gzip > database.sql.gzip
4

3 回答 3

13

您可以--init-command在每个会话的基础上使用该标志:

mysql --init-command="SET SESSION FOREIGN_KEY_CHECKS=0;" ... < dump.sql
于 2017-02-16T03:36:21.923 回答
10

从这个 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 */;

于 2012-06-12T20:21:34.007 回答
10

这很难看,但我最终只是修改了架构文件以删除外键。


仅转储模式,没有外键

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)。

于 2018-04-24T21:15:47.370 回答