我正在将旧的 Sybase 数据库迁移到 MySQL,并且必须创建外键。现在,由于 Sybase 导出其数据,我尝试像在 MySQL 上一样使用其查询:
ALTER TABLE Mosaico.fornit_col
ADD FOREIGN KEY fkey_fco_fornit_maz ( fco_idformaz )
REFERENCES Mosaico.fornit_maz ( fma_id );
--
ALTER TABLE Mosaico.fornit_col
ADD FOREIGN KEY fkey_fco_mater_col ( fco_idmatcol )
REFERENCES Mosaico.mater_col ( mco_id );
--
而且似乎效果很好。 如果我在 MySQL 管理控制台上执行它们,查询就会工作,但在 Workbench 上,第二个查询会出现此错误:
ALTER TABLE Mosaico.fornit_col ADD FOREIGN KEY fkey_fco_mater_col ( fco_idmatcol ) REFERENCES Mosaico.mater_col ( mco_id ) Error Code: 1050. Table '.\mosaico\fornit_col' already exists
有什么问题吗?
最佳答案
在此处查看错误报告:
最后,有问题的人升级了他们的服务器并解决了问题。通过阅读它,我不确定其中的某个地方没有错误。他们确实有一些解决方法,例如输入约束名称/更改它们。尝试他们的一些修复。如果您认为这是相同的,并且您可以重复该错误,我会请求重新打开该错误。
有一次,他们提到类型不匹配,工作台响应错误错误(应该是 errno 150 或 errno 121)。您可以在此处查看这些错误的原因: MySQL Foreign Key Errors and Errno 150
关于mysql - 关于mysql的外键,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11029078/