对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了。
感觉比oracle、sqlserver复杂啊,不知道这样有什么好的好处,看来得好好学习下mysql了。