MySQL数据库建立外键失败的原因总结

数据库 MySQL
本文主要总结了几种MySQL创建外键失败时可能的原因,并按照可能性的大小进行了排序,希望能够对您有所帮助。

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/,相信一定可以带给您收获的!

【编辑推荐】

  1. MySQL数据库命令行常用命令大全总结篇
  2. MySQL数据库如何实现跨表更新与数据并合
  3. MySQL数据库修改MySQL密码的六种措施总结
  4. MySQL数据库如何删除表中部分关键字段重复的记录
  5. 如何解决MySQL数据库主从服务器之间数据有差距问题
责任编辑:赵鹏 来源: 博客园
相关推荐

2010-10-09 10:29:29

MySQL外键

2011-09-01 10:56:34

2010-01-05 09:24:42

MySQL外键约束

2010-05-11 18:46:46

MYSQL 外键

2010-05-17 16:10:39

MySQL数据库

2019-11-05 08:20:13

MySQL数据库外键

2010-06-17 17:50:31

SQL Server外

2010-09-13 13:44:22

sql server外

2011-08-03 17:43:53

MySQL数据库外键约束

2016-12-29 12:24:33

MySQL数据库移植

2019-01-02 11:10:40

MySQL数据库数据库设计

2020-06-09 09:19:14

数据库

2010-06-04 19:24:15

重装MySQL数据库

2009-02-03 13:06:17

日常维护规范MySQL

2010-05-24 17:54:25

2019-07-11 08:45:00

MySQL数据库缓存

2011-08-22 15:31:51

SQL Servermssqlserver数据库复制

2018-11-29 14:30:42

数据库外键约束应用程序

2011-03-03 10:00:14

ProFTPD建立MySQL

2010-10-09 09:55:41

MySQL外键
点赞
收藏

51CTO技术栈公众号