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