对mysql数据库不太熟悉,今天遇到了外键创建问题。alter外键创建语句命令行下提示成功了,但就是没看到外键。
后来改用workbench工具来创建,发现是因为数据默认是采用的MyISAM存储引擎,该引擎不支持外键,需要修改引擎为InnoDB才可以。
我直接在workbench将表的引擎改为了InnoDB,发现还是不行,报1005错误:
- 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 就可以了