java - 删除MYSQL中的僵尸外键

标签 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)

如何摆脱这些僵尸约束?

最佳答案

最后,我必须重新创建表和外键,然后才能将其删除。

关于java - 删除MYSQL中的僵尸外键,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60320636/

相关文章:

java - jackson : Inheritance and required attributes

php - WordPress $wpdb 自定义查询不起作用

java - 使用hibernate java mysql保存@Lob时出错

java - ehcache xml 需要 defaultCache 元素,其他缓存正在获取 defaultCache 属性

java - 处理 JavaFX 事件,例如从文本字段控件捕获文本

java - 在Java中将其添加和存储在数组中之前如何检查和输入?

Java - 通过程序方式创建注释

mysql - AWS RDS 中 max_connections 的值

mysql - self 加入 self 引用条件

java - JPA 从其他字段计算字段