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

mysql外键设置不成功_MySQL数据库建立外键失败的原因总结相关推荐

  1. mysql中外键设置级联删除_MySQL中利用外键实现级联删除、更新

    MySQL中利用外键实现级联删除.更新 MySQL支持外键的存储引擎只有InnoDB,在创建外键的时候,要求父表必须有对应的索引,子表在创建外键的时候也会自动创建对应的索引.在 创建索引的时候,可以指 ...

  2. oracle数据库建立外键级联删除

    在给已存在的oracle数据表建立外键时命令为: alter table tablename add constraint FK_NAME foreign key(tablefile) referen ...

  3. mysql外键约束查询语句_MySQL数据库 : 查询语句,连接查询及外键约束

    查询指定字段        select 字段1,字段2 from 表名; 消除重复行(重复指的是结果集中的所有完全重复行)             select distinct 字段1,字段2.. ...

  4. mysql如何建外建_mysql如何建立外键

    mysql如何建立外键 一个主表blog博客表, DROP TABLE IF EXISTS  `blog`; CREATE TABLE `blog` ( `id` int(11) NOT NULL a ...

  5. mysql设置约束l命令_MYSQLl数据库主键设置长度控制_MySQL

    bitsCN.com MYSQLl数据库主键设置长度控制 1.出现的问题? JEECMS套件(jeecms-2012-sp1)中有一个jeecms-db-2012-sp1.sql文件,文件里面有一张& ...

  6. mysql主键约束和外键约束的作用_MySQL中的主键约束和外键约束

    1.主键约束 表通常具有包含唯一标识表中每一行的值的一列或一组列. 这样的一列或多列称为表的主键 (PK),用于强制表的实体完整性. 由于主键约束可保证数据的唯一性,因此经常对标识列定义这种约束. 如 ...

  7. mysql中的foreignkey的作用_mysql中的外键foreign key

    一.如果一张表中有一个非主键的字段指向了别一张表中的主键,就将该字段叫做外键. 一张表中可以有多个外键. 外键的默认作用有两点: 1.对子表(外键所在的表)的作用:子表在进行写操作的时候,如果外键字段 ...

  8. mysql四列数据表代码_MySQL数据库常用代码

    MySQL数据库常用代码启动数据库服务:[ net Start MySQL ] 使用命令登录:[ Mysql -h localhost -u root -p] 关闭数据库服务: [net stop m ...

  9. 在mysql中怎样设置值唯一_mysql怎么设置行值唯一?

    mysql可通过给行(字段)添加唯一性约束来设置行值唯一,语法格式"CREATE TABLE 表名 (字段名 数据类型 UNIQUE);"和"ALTER TABLE 表名 ...

最新文章

  1. 谈钱太俗!难道开源软件只能讲道义?
  2. 如何理解c和c ++的复杂类型声明 (转)
  3. ThinkSNS 仿蘑菇街 社区购物分享系统
  4. PDF解决方案(2)--文件转PDF
  5. 萤火虫pte小程序_【PTE战报】84炸的Maggie,RS试试这样入手开始练习
  6. Linux实训项目——第八章:配置网络接口及远程管理
  7. 树莓派4B之雨滴雨水传感器模块(python3)
  8. 正版破解软件下载站大全(转载
  9. [C++]什么是句柄?为什么会有句柄?
  10. excel打不开服务器上的文件夹,Excel打不开的原因及解决方法汇总
  11. DBF文件使用JAVA读写解决方案
  12. [Irving]Android 常用布局之RelativeLayout
  13. 视频教程-Oracle数据库开发技巧与经典案例讲解一-Oracle
  14. 提供一个vs6,vs2005,vs2008,office2007可以下载的地址.
  15. 解决webpack打包样式url()背景图片问题
  16. ALSA应用层编程播放音乐
  17. [Unity] Unity获得Android的视频缩略图
  18. EGL Driver message (Critical) eglInitialize: No available renderers.
  19. 惯量比多少合适_伺服电机负载惯量比的合理取值汇总
  20. C# 从零开始写 SharpDx 应用 笔刷

热门文章

  1. SAP案例教程FI财务后台配置
  2. 透过J2Cache的吐槽,领悟代码的设计
  3. 2018深信服java笔试题_2018校招深信服编程题与面试题
  4. 人才缺口上百万,年薪50万+!
  5. java大学生网上请假系统ssm框架
  6. 系统cpu主频查看设置
  7. 亚马逊内部文件泄露,程序员薪酬高达 462 万元
  8. python在abaqus中的应用光盘文件下载_python语言在abaqus中的应用随书光盘.rar-讲义文档类资源...
  9. 【读者来信】培训完没有类似的工作经验,该如何找工作?
  10. IntelliJ IDEA java项目导入jar包,打jar包