MYSQL mysql 无法创建外键约束 及 errno: 121错误

对mysql数据库不太熟悉,今天遇到了外键创建问题。alter外键创建语句命令行下提示成功了,但就是没看到外键。

后来改用workbench工具来创建,发现是因为数据默认是采用的MyISAM存储引擎,该引擎不支持外键,需要修改引擎为InnoDB才可以。

我直接在workbench将表的引擎改为了InnoDB,发现还是不行,报1005错误:

[sql] view plain copy print ?
  1. 10:31:56    ALTER TABLE `cm_relation_contact_group`     ADD CONSTRAINT `fk_test`    FOREIGN KEY (`groupId` )    REFERENCES `cm_group` (`id` )    ON DELETE NO ACTION    ON UPDATE NO ACTION  , ADD INDEX `fk_test` (`groupId` ASC)  Error Code: 1005. Can't create table 'callcenter.#sql-728_5c92' (errno: 150)  
10:31:56	ALTER TABLE `cm_relation_contact_group`     ADD CONSTRAINT `fk_test`    FOREIGN KEY (`groupId` )    REFERENCES `cm_group` (`id` )    ON DELETE NO ACTION    ON UPDATE NO ACTION  , ADD INDEX `fk_test` (`groupId` ASC)	Error Code: 1005. Can't create table 'callcenter.#sql-728_5c92' (errno: 150)

上网google了一把,大家总结了下,大致有以下原因:

1、外键的引用类型不一样,主键是int外键是char 
2、找不到主表中 引用的列 
3、主键和外键的字符编码不一致 
4.还有要建立外键的话,要先建立索引。没有建立索引也会出错。
 

我逐个检查了下,都没问题。难道是每个表都有引擎设置,打开被引用表,发现引擎还是MyISAM,修改过来后就OK了。

 

 

我在MYSQL中建立个表,就能报[Err] 1005 - Can't create table '.\qesplatform_dbdldx\p_users.frm' (errno: 121),没有外键,请问如何解决

 

(errno: 121), 这是外关键字名字重复的错误,即使是在不同的表中,外关键字的名字也不能重复
我的是FK_Reference_4 重复了,找个没有的FK_Reference_54 就可以了

 

你可能感兴趣的:(MYSQL)