日期:2014-05-16  浏览次数:20723 次

mysql 建外键的时候出150错误
在MySQL里创建外键时(Alter table xxx add constraint fk_xxx foreign key),提示错误,但只提示很简单的信息:ERROR 1005 (HY000): Can't create table '.\env_mon\#sql-698_6.frm' (errno: 150)。根本起不到解决问题的作用。

要看错误的详细提示,可以使用命令:(在MySQL Manual里搜索“errno 150”时找到)

SHOW ENGINE INNODB STATUS;     //针对用INNODB存储方式的数据库

在信息中有一组【LATEST FOREIGN KEY ERROR】会有最近错误的详细描述和解决办法。
如:
Cannot find an index in the referenced table where the referenced columns appear as the first columns, or column types in the table and the referenced table do not match for constraint.
(译:不能在“被reference的表”里找到包含“被reference字段”的索引,或者是两个关联字段类型不匹配)。我今天碰到的问题不是上面出现的2中情况,而且2个表的语言类型不一样,一个是InnoDB,而宁一是MyISAM,后者是Mysql建立表的时候默认的Engine,而且它不支持创立外键,所以我就改成InnoDB,这样2个表的Engine就不一样了,然后就再修改宁外一个表的Engine也为InnoDB。这样就可以建立外键了。说明我用的mysql 图像界面是MysqlFront。