MySQL数据库建立外键失败的原因总结
2013-12-10 21:28
337 查看
在MySQL数据库创建外键时,经常会发生一些错误,这是一件很令人头疼的事。一个典型的错误就是:Can’t create table... 的错误。在很多实例中,这种错误的发生都是因为mysql一直以来都不能很好的支持的关系的问题, 更不幸的是它也并没有指明到底是哪一个问题会导致上面那种错误,下面我把导致这个可怕的150错误的常见原因列出来了,并且我以可能性的大小作了排序,已知的原因:
1.两个字段的类型或者大小不严格匹配,例如,如果一个是INT(10), 那么外键也必须设置成INT(10), 而不是 INT(11) 也不能是TINYINT. 你得使用SHOW命令来查看字段的大小,因为一些查询浏览器有时候把int(10) 和int(11) 都显示为integer。另外,你还必须确定两个字段是否一个为SIGNED,而另一个又是UNSIGNED, 这两字段必须严格地一致匹配,更多关于signed 和unsigned的信息,请参阅:http://www.verysimple.com/blog/?p=57 。
2.你试图引用的其中一个外键没有建立起索引,或者不是一个primary key , 如果其中一个不是primary key 的,你必须为它创建一个索引。
3.外键的名字是一个已经存在的一个键值了,这个时候,你应该检查你的数据库以确保外健名字是唯一的,或者你在键名后面加上几个随机的字符以测试是否是这个原因。
4.其中一个或者两个表是MyISAM引擎的表,若想要使用外键约束,必须是InnoDB引擎,(实际上,如果两个表都是MyISAM 引擎的,这个错误根本不会发生,但也不会产生外键),你可以通过查询浏览器来设置表的引擎类型。
5.你可能设置了ON DELETE SET NULL, 但是相关的键的字段又设置成了NOTS NULL 值。你可能通过修改cascade 的属性值或者把字段属性设置成allow null来搞定这个bug.
6.请确定你的Charset 和 Collate 选项在表级和字段级上的一致。
7.你可能设置为外键设置了一个默认值,如default=0。
8.在这个关系里面,其中的一个字段是一个混合键值中的一个,它没有自己独立的索引,这时,你必须为它创建一个独立的索引。
9.ALTER 声明中有语法错误。
以上就是MySQL创建外键失败时可能原因的总结,如果您想了解更多关于MySQL数据库的内容,可以看一下这里的文章:http://database.51cto.com/mysql/,相信一定可以带给您收获的!
From: http://database.51cto.com/art/201108/280088.htm
1.两个字段的类型或者大小不严格匹配,例如,如果一个是INT(10), 那么外键也必须设置成INT(10), 而不是 INT(11) 也不能是TINYINT. 你得使用SHOW命令来查看字段的大小,因为一些查询浏览器有时候把int(10) 和int(11) 都显示为integer。另外,你还必须确定两个字段是否一个为SIGNED,而另一个又是UNSIGNED, 这两字段必须严格地一致匹配,更多关于signed 和unsigned的信息,请参阅:http://www.verysimple.com/blog/?p=57 。
2.你试图引用的其中一个外键没有建立起索引,或者不是一个primary key , 如果其中一个不是primary key 的,你必须为它创建一个索引。
3.外键的名字是一个已经存在的一个键值了,这个时候,你应该检查你的数据库以确保外健名字是唯一的,或者你在键名后面加上几个随机的字符以测试是否是这个原因。
4.其中一个或者两个表是MyISAM引擎的表,若想要使用外键约束,必须是InnoDB引擎,(实际上,如果两个表都是MyISAM 引擎的,这个错误根本不会发生,但也不会产生外键),你可以通过查询浏览器来设置表的引擎类型。
5.你可能设置了ON DELETE SET NULL, 但是相关的键的字段又设置成了NOTS NULL 值。你可能通过修改cascade 的属性值或者把字段属性设置成allow null来搞定这个bug.
6.请确定你的Charset 和 Collate 选项在表级和字段级上的一致。
7.你可能设置为外键设置了一个默认值,如default=0。
8.在这个关系里面,其中的一个字段是一个混合键值中的一个,它没有自己独立的索引,这时,你必须为它创建一个独立的索引。
9.ALTER 声明中有语法错误。
以上就是MySQL创建外键失败时可能原因的总结,如果您想了解更多关于MySQL数据库的内容,可以看一下这里的文章:http://database.51cto.com/mysql/,相信一定可以带给您收获的!
From: http://database.51cto.com/art/201108/280088.htm
相关文章推荐
- MySQL数据库建立外键失败的原因总结
- MySQL数据库建立外键失败的原因总结
- Navicat建立外键失败原因总结
- mysql添加外键失败原因总结
- mysql数据库建立外键老是失败?
- MySQL外键创建失败1005原因总结
- 安卓(android)建立项目时失败,出现Android Manifest.xml file missing几种解决方法?(总结中)
- MySQL外键创建失败1005原因汇总
- 域信任建立失败-建立信任关系不能继续,原因是:账户已存在
- MYSQL建立外键失败几种情况记录Can’t create table...
- iOS开发之第三方分享微博分享、微博分享失败原因总结,史上最新最全第三方分享微博方式实现。 微博分享各种坑总结
- Spring注入失败可能的几个原因总结
- 总结:导致项目失败的3个层次和14个原因
- mysql设置外键失败原因
- 数据库 创建外键失败 原因枚举
- mysql 外键添加失败原因
- mysql创建外键失败原有总结
- Mysql学习总结(19)——Mysql无法创建外键的原因
- dlopen Linux 动态库失败原因与解决办法总结