从mysql数据库中导出正常数据库的脚本语句,而后使用脚本语句创建数据库的过程中,执行语句提示Can't Create Table 'XXX' erro150的错误,语句执行中断,创建table失败,仔细分析相关语句发现导致此错误的原因为创建的外键和关联的表的主键类型不匹配。

仔细查看被执行的语句,发现无法执行的table语句中含有CONSTRAINT关键字和FOREIGN KEY 外键关键字,因此判断该table的创建必须在外键表创建完成之后才可执行,找不到引用外键的表导致语句执行失败,遂先找到外键表table先创建,并写入数据,而后再执行上述错误语句,最后执行成功。

解决完此问题后,在网上查阅了相关资料,总结后有下列几个情况会出现错误Can't Create Table 'XXX' erro150。

(1)两个表格的外键关联字段的类型不一致不匹配。例如:A表和B表关联字段为teacherid,但A表中的teacherid为varchar类型,B表中的teacherid字段为int类型,此情况是无法进行外键关联的。

(2)两个表的外键的类型一致,但字符编码不一样,如A表的关联字段的字符编码为utf8_unicode_ci,B表的关联字段的字符编码为utf8_general_ci。

(3)找不到外键引用的列。如找不到外键对应的数据表table,或者外键表中不存在该列名。

备注:原文转载自Mysql创建表时报错error150_IT技术小趣屋

最新文章

  1. grep笔记
  2. python None与Null
  3. loadrunner常用函数
  4. android中ADT和SDK的关系(转)
  5. python 电影下载链接爬虫
  6. 跨平台音乐播放器qmmp(Cross-Platform Audio Player Qmmp)
  7. Codeforces Beta Round #18 (Div. 2 Only) C. Stripe 前缀和
  8. Cocos2d-x开发实例介绍特效演示
  9. C#中对于float,double,decimal的误解
  10. hibernate入门程序
  11. Gson解析第三方提供Json数据(天气预报,新闻等)
  12. [转载] Oracle之内存结构(SGA、PGA)
  13. angular 1.x 控制器之间互相传递参数
  14. [整理]Error: [ngRepeat:dupes]的解决方法
  15. Tomcat下HTTPS双向认证配置以及客户端调用案例
  16. PHP中“==”运算符的安全问题
  17. 【BZOJ1859】【ZJOI2006】碗的叠放
  18. 【java】获取解析资源文件的方法
  19. hasOwnProperty()与in操作符的区别
  20. E20181120-hm

热门文章

  1. 用Service+Broadcast解决倒计时过程中Activity被销毁的问题
  2. HrbustOJ 1564 螺旋矩阵
  3. [Hyperledger] Fabric系统中 peer模块的 gossip服务详解
  4. TensorFlow读写数据
  5. 锁开销优化以及 CAS 简单说明
  6. 设计模式之面向切面编程AOP
  7. FontAwesome 图标字体库的使用
  8. 在线修改redo日志大小
  9. sql server2005安装时报 ‘服务无法启动’
  10. @Autowired注解警告Field injection is not recommended