在MYSQL中删除僵尸外键

时间:2020-02-20 13:06:11

标签: java mysql jpa foreign-keys schema

我正在尝试通过使用JPA和Eclipse-Link进行生成来逐步构建MySQL数据库。在此过程中,我更改了一些关系@ManyToOne@OneToOne等。

我现在遇到了一些虚假外键的情况:这些表不存在,但被引用的表仍然存在。我认为原始表是EclipseLink生成的交叉引用表,但不再存在。

问题是,我无法删除这些引用的表。我收到这样的错误:

mysql> drop table PRODUCTDO;
ERROR 3730 (HY000): Cannot drop table 'PRODUCTDO' referenced by a foreign key constraint 'PRODUCTDO_DISTRIBUTIONCENTERPRODUCTDO_ProductDo_ID' on table 'PRODUCTDO_DISTRIBUTIONCENTERPRODUCTDO'.

如果我跑步:

SET foreign_key_checks = 0;

然后我可以删除表,但是约束仍然存在。即使我删除数据库并再次创建它,约束仍然存在:

mysql> SELECT    TABLE_NAME,COLUMN_NAME,CONSTRAINT_NAME, REFERENCED_TABLE_NAME,REFERENCED_COLUMN_NAME FROM   INFORMATION_SCHEMA.KEY_COLUMN_USAGE WHERE REFERENCED_TABLE_SCHEMA = 'SCO';
+---------------------------------------+------------------------------+----------------------------------------------------+-----------------------------+------------------------+
| TABLE_NAME                            | COLUMN_NAME                  | CONSTRAINT_NAME                                    | REFERENCED_TABLE_NAME       | REFERENCED_COLUMN_NAME |
+---------------------------------------+------------------------------+----------------------------------------------------+-----------------------------+------------------------+
| PRODUCTDO_DISTRIBUTIONCENTERPRODUCTDO | ProductDo_ID                 | PRODUCTDO_DISTRIBUTIONCENTERPRODUCTDO_ProductDo_ID | PRODUCTDO                   | ID                     |
| PRODUCTDO_DISTRIBUTIONCENTERPRODUCTDO | distributionCenterProduct_ID | PRDCTDDSTRBTIONCENTERPRODUCTDOdstrbtnCntrProductID | DISTRIBUTIONCENTERPRODUCTDO | ID                     |
+---------------------------------------+------------------------------+----------------------------------------------------+-----------------------------+------------------------+
2 rows in set (0.01 sec)

如何摆脱这些僵尸约束?

1 个答案:

答案 0 :(得分:0)

最后,我不得不重新创建表和外键,然后才能删除它。