从 PHPMYADMIN 导出和导入数据

Posted

技术标签:

【中文标题】从 PHPMYADMIN 导出和导入数据【英文标题】:Export and import data from PHPMYADMIN 【发布时间】:2012-07-13 04:53:21 【问题描述】:

我使用 phpMyAdmin 导出数据,但是当我导入数据时出现此错误:

#1452 - 无法添加或更新子行:外键约束失败

我可以相应地设置数据,然后我没有收到错误。但是有没有更好的方法来做到这一点?比如禁用 phpMyAdmin 中的某些选项或向 SQL 添加一些查询?

【问题讨论】:

PMA 过去一直在做这样的事情,但最近它变得更好了(根据我的经验)。基本上导出文件中某些操作的顺序是错误的。我会在导出和导入服务器上更新 PMA,然后重试,您可能会发现它消失了。 你可以试试当你检查“在事务中包含导出”、“禁用外键检查”和“扩展插入”时它是否有效? 【参考方案1】:

问题是 pma 不关心插入行的顺序。所以它会发生一个表行插入一个 FK 尚未导入 FK 行的地方。

要解决此问题,请在从 PhpMyadmin 导出时使用复选框 Disable Foreign Key Checks。或者自己设置:

SET FOREIGN_KEY_CHECKS=0;

最后:

SET FOREIGN_KEY_CHECKS=1;

【讨论】:

【参考方案2】:

mysql FK Doc 中引用了该错误 (Cannot add or update a child row: a foreign key constraint fails)

要在 2 个表之间添加引用,条件必须适合现有数据。

这意味着如果你说table1.id = table2.id,那么table1table2 的所有id 必须匹配在一起。

要解决这个问题,您必须消除或修复那些不匹配的行。 示例:

table1.id  |  table2.fk
   1       |       1      ok 
   2       |     null     error
   3       |       4      error if id 4 is not in table1

【讨论】:

对错误的解释很好,但是结果是错误的......它只是pma在生成sql文件时不关心表的顺序。

以上是关于从 PHPMYADMIN 导出和导入数据的主要内容,如果未能解决你的问题,请参考以下文章

如何利用phpmyadmin导入和导出mysql数据库

如何利用phpmyadmin导入和导出mysql数据库

无法导入从 phpMyAdmin 导出的 sql 文件

使用 phpmyadmin 导出/导入 mysql 数据库

如何利用phpmyadmin导入和导出mysql数据库

从 phpMyAdmin 使用导出/导入 SQL 文件时出错