mysql 无法创建外键约束

时间:2022-09-21 13:04:25

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

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

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

10:31:56ALTER 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 无法创建外键约束感觉比oracle、sqlserver复杂啊,不知道这样有什么好的好处,看来得好好学习下mysql了。