mysql error:150错误外键问题

mysql error:150错误外键问题
 
ERROR 1005 (HY000): Can't create table '  ****.frm' (errno: 150)
   www.2cto.com  
问题
1、确保参照的表和字段是存在的; 
2、组成外键的字段要求被索引(主要是外键那个字段要求在其他表中是主键);
3、外键关联的两表或多表要求都是INNODB类型的表;
4、字段类型(说明)要一样
 
从workbench导出的sql就是之一插入不了 数据库,之前还可以,留下来做个记录吧。
 
第一和第四条都比较清楚,标注一下第2、3条。
  www.2cto.com  
2. 要求在该字段建立索引,我就是遇到这个问题,之前外键关联的字段改成了另一个,它是主键,但是是联合的,也就是建立了联合索引,这种情况下建立外键在这个键上 mysql是不支持的,因此需要注意,必须是单独建立在这个键上了索引才行。
 
3. INNODB支持外键,MyISAM引擎不支持外键。
因此主要查看这两种错误,用工具建立的表一般不会出现1、4种错误,希望帮到看到文章的人减少浪费的时间。也做个记录。关于innodb   http://imysql.cn/taxonomy/term/21 点击打开链接

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值