0

我正在将旧的 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

有什么问题?

4

1 回答 1

1

在此处查看错误报告:

MySQL 错误 55296

最后,有问题的人升级了他们的服务器并解决了问题。通过阅读它,我不确定某处是否存在错误。他们确实有一些解决方法,例如输入约束名称/更改它们。尝试他们的一些修复。如果您认为这是相同的,并且您可以重复错误,我会要求重新打开该错误。

有一次,他们提到类型不匹配并且工作台响应错误错误(应该是 errno 150 或 errno 121)。您可以在此处查看这些错误的原因: MySQL Foreign Key Errors and Errno 150

于 2012-06-15T18:13:00.623 回答