首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

如何处理 MySQL错误码 1215:无法添加外键约束?

本文为作者翻译文章,原文链接:Dealing with MySQL Error Code 1215: “Cannot add foreign key constraint” 在给一个表创建外键时,MySQL...总是会出现提示: ERROR 1215 (HY000): Cannot add foreign key constraint 这信息基本是啥都没说,下面就来说说几种常见的导致1215错误的情况: 父表不存在...REFERENCES pariente(id); 正确: ALTER TABLE child ADD FOREIGN KEY (parent_id) REFERENCES parent(id); 父列和子列数据类型不一致...3_idx (column_2, column_3), -> KEY column_4_idx (column_4) -> ) ENGINE INNODB; #错误:因为父表column_1列上没有任何索引...parent_virt INT(10) NOT NULL, FOREIGN KEY (parent_virt) REFERENCES parent(column_virt) ) ENGINE INNODB; 创建外键失败的更多提示信息

21.5K21
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    MySQL 外码约束原理:如何解决数据库添加数据时产生的外码(外键)约束?

    文章目录 前言 一、插入新数据时报错外键约束? 二、对于出错 SQL 语句的分析 三、对于外码约束的分析 四、如何处理外键约束?...总结 ---- 前言 我们在使用 MySQL 数据库时,添加数据如果设计不合理很容易出现外码约束的情况,为什么会产生这样的问题?那我们该如何处理这一问题呢?依据又是什么?...我们在 Course 表中插入课程号为 1 的数据时提示违反了外键约束,插入命令如下: insert into course(cno,cname,cpno,ccredit) values('1','数据库...三、对于外码约束的分析 我们根据数据库定义的参照完整性规则得知:外键 cpno 的取值不为空的情况下(如上 cpno=‘5’),与其对应的主键 cno 在参照表中必须存在。...但是我们反观上面操作,第一个插入的就是 cno=‘1’ 的数据,cno=‘5’ 的还没有插入,很显然不满足参照完整性规则。 四、如何处理外键约束?

    3.2K20

    mysql如何添加一个表的外键

    1:创建一个父表,主键作为子表的外键: 1 create table province( 2 pId int primary key auto_increment, 3 pName varchar...(20) 4 ); 2:创建子表,外键是父表的主键: 1 create table user( 2 userId int primary key auto_increment, 3 userName varchar...(40), 4 pid int, 5 foreign key(pid) references province(pId) 6 ); 给一张表添加外键,即给子表的外键添加主键的规则: 在子表声明一个字段pid...int,用于作为子表的外键,foreign key(子表的外键字段) references 父表的表名(父表的主键的字段名); 3:当创建好数据表时添加外键约束: alter table user add...foreign key(pid) references province(pId); alter table 子表的数据表名 add foreign key(子表的外键名称) references 父表的数据表名称

    4.3K70

    js数组添加删除数据_如何删除数组中的元素

    文章目录 添加删除数组元素的方法 ---- 添加删除数组元素的方法 // 添加删除数组元素的方法 // 1.push()在我们数组的末尾 添加一个或者多个数组元素 var arr...//(2)push 参数直接写 数组元素就可以了 // (3)push完毕后 返回的结果是新数组的长度 // (4)原数组也会发生变化 // 2.unshift 在我们数组的开头 添加一个或者多个数组元素...unshift 完毕后 返回的结果是新数组的长度 // (4)原数组也会发生变化 //3.删除数组元素pop() 它可以删除数组的最后一个元素 console.log(arr.pop()); //返回删除的元素...(4)原数组也会发生变化 //34.删除数组元素shift() 它可以删除数组的最后一个元素 console.log(arr.shift()); //返回删除的元素 console.log(arr);...// (1)shift 是可以删除数组的第一个元素,但是一次只能删除一个元素 // (2)shift没有参数 // (3)shift 完毕后 返回的结果是删除的元素 // (4)原数组也会发生变化 </

    14.4K10

    MySQL 数据库添加数据时为什么会产生外码(外键)约束?原理就是什么?如何解决?

    文章目录 前言 一、插入新数据时报错外键约束? 二、对于出错 SQL 语句的分析 三、对于外码约束的分析 四、如何处理外键约束?...总结 ---- 前言 我们在使用 MySQL 数据库时,添加数据如果设计不合理很容易出现外码约束的情况,为什么会产生这样的问题?那我们该如何处理这一问题呢?依据又是什么?...我们在 Course 表中插入课程号为 1 的数据时提示违反了外键约束。...三、对于外码约束的分析 我们根据数据库定义的参照完整性规则得知:外键 cpno 的取值不为空的情况下(如上 cpno=‘5’),与其对应的主键 cno 在参照表中必须存在。...但是我们反观上面操作,第一个插入的就是 cno=‘1’ 的数据,cno=‘5’ 的还没有插入,很显然不满足参照完整性规则。 四、如何处理外键约束?

    3K31

    oracle基础|数据库如何设计|数据库的六种范式|数据库的主键和外键|数据库的约束

    目录 一、数据库设计 二、数据库六种范式 第一范式: 第二范式: 第三范式: 三、主键和外键 主键: 外键: 四、完整性约束 五、建表 六、oracle数据库中的多种数据结构 ---- 一、数据库设计...,要求这几个列的值联合在一起是非空唯一的 外键: 1.表中的某一个列声明为外键列,一般这个外键列的值都会引用于另外一张表的主键列的值(有唯一约束的列就可以,不一定非要引用主键列) 2.另外一张表的主键列中出现过的值都可以在外键列中使用...3.外键列值也可以为空的,提前是这个外键列在表中不做主键,因为我们也可以把表中的外键列当做主键来使用(只有满足非空唯一的要求就可以) 4.如果把B表中的联合主键的值引用到A表中做外键,因为是俩个列在B...表中做联合主键,那么A表引用过来的时候也要把俩个列的值都引用过来,那么它们在A表中就会作为一个联合外键出现 四、完整性约束 实体完整性: 引用完整性 列级完整性 用户自定义 五、建表 1.映射实体---...-表 2.映射属性----列 3.添加约束 4.描述关系信息(外键) 六、oracle数据库中的多种数据结构 1.表结构 存储数据 2.视图 一张表或多张表中数据的字节

    72940

    PostgreSQL 教程

    重命名表 将表的名称更改为新名称。 添加列 向您展示如何向现有表添加一列或多列。 删除列 演示如何删除表的列。 更改列数据类型 向您展示如何更改列的数据。 重命名列 说明如何重命名表中的一列或多列。...了解 PostgreSQL 约束 主题 描述 主键 说明在创建表或向现有表添加主键时如何定义主键。 外键 展示如何在创建新表时定义外键约束或为现有表添加外键约束。...检查约束 添加逻辑以基于布尔表达式检查值。 唯一约束 确保一列或一组列中的值在整个表中是唯一的。 非空约束 确保列中的值不是NULL。 第 14 节....UUID 指导您如何使用UUID数据类型以及如何使用提供的模块生成UUID值。 数组 向您展示如何使用数组,并向您介绍一些用于数组操作的方便函数。...hstore 向您介绍数据类型,它是存储在 PostgreSQL 中单个值中的一组键/值对。 JSON 说明如何使用 JSON 数据类型,并向您展示如何使用一些最重要的 JSON 运算符和函数。

    59210

    【MySQL】04_约束

    ,然后才可以删除主表的数据 在“从表”中指定外键约束,并且一个表可以建立多个外键约束 从表的外键列与主表被参照的列名字可以不相同,但是数据类型必须一样,逻辑意义一致。...(根据外键查询效率很高) 删除外键约束后,必须 手动 删除对应的索引 添加外键约束 建表时 create table 主表名称( 字段1 数据类型 primary key, 字段2 数据类型 );...约束关系是针对双方的 添加了外键约束后,主表的修改和删除数据受约束 添加了外键约束后,从表的添加和修改数据受约束 在从表上建立外键,要求主表必须存在 删除主表时,要求从表从表先删除,或将从表中外键引用该主表的关系先删除...约束等级 Cascade方式 :在父表上update/delete记录时,同步update/delete掉子表的匹配记录 Set null方式 :在父表上update/delete记录时,将子表上匹配记录的列设为...不建外键约束,你的操作(创建表、删除表、添加、修改、删除)不受限制,要保证数据的 引用完整性 ,只能依 靠程序员的自觉 ,或者是 在Java程序中进行限定 。

    2.4K20

    mysql学习笔记(四)约束与索引

    表具有一些特性,这些特性定义了数据在表中如何存储 表由列组成,我们也称为字段,每个字段描述了它所含有的数据的意义,数据表的设计实际上就是对字段的设计 表的数据按行存储 约束与索引 完整性 数据完整性(Data...一个表可以有很多的外键约束 外键约束需要一个表的两个字段或者两个表的两个字段之间建立外键约束 外键约束一定是在从表、子表中建立的。...例如选课表,表中有两个外键,分别参考学生表和课程表 约束的五个等级: cascade方式:级联,主动权在主表上,如果主表被依赖字段修改了,从表的外键字段也会跟着修改。...set null方式:主动权在主表上,如果主表被依赖字段修改了,从表的外键字段会将值设置为Null,这里要求,外键字段不能有非空约束。...set default方式:主动权在主表上,如果主表被依赖字段修改了,从表的外键字段会将值设置为default,这里要求,外键字段必须有默认约束。

    2.1K00

    2024Mysql And Redis基础与进阶操作系列(4)作者——LJS

    因为被依赖/被参考的值必须是唯一的 在创建外键约束时,如果不给外键约束命名,默认名不是列名,而是自动产生一个外键名 例如 student_ibfk_1,也可以指定外键约束名。...如果要删除数据,需要先删除从表中依赖该记录的数据,然后才可以删除主表的数据 在“从表”中指定外键约束,并且一个表可以建立多个外键约束 从表的外键列与主表被参照的列名字可以不相同,但是数据类型必须一样,逻辑意义一致...emp引用了,所以部门表的 1001字段对应的记录就不能被删除 总结: 约束关系是针对双方的 添加了外键约束后,主表的修改和删除数据受约束 添加了外键约束后,从表的添加和修改数据受约束 在从表上建立外键...掉子表的匹配记录 Set null方式 在父表上update/delete记录时,将子表上匹配记录的列设为null,但是要注意子表的外键列不能为not null No action方式 如果子表中有匹配的记录...比如:在员工表中,可以添加一个员工的信息,它的部门指定为一个完全不存在的部门。 问题3:那么建和不建外键约束和查询有没有关系?

    11310

    MySQL数据库,从入门到精通:第十三篇——MySQL数据表约束详解

    接着讲解了非空约束、唯一性约束和主键约束的使用方法,以及如何添加、删除和使用复合约束等技巧。 在自增列和外键约束方面,本文详细介绍了其作用和关键字,以及如何指定和删除自增约束和外键约束等技巧。...同时,针对复杂场景,本文也讲解了外键约束的等级、开发场景和阿里开发规范等内容。 接着讲解了默认值约束和CHECK约束的使用方法,以及如何给字段加默认值和如何添加CHECK约束的技巧。...引用了,所以部门表的 1001字段对应的记录就不能被删除 总结:约束关系是针对双方的 添加了外键约束后,主表的修改和删除数据受约束 添加了外键约束后,从表的添加和修改数据受约束 在从表上建立外键,要求主表必须存在...Set null方式:在父表上update/delete记录时,将子表上匹配记录的列设为null,但是要注意子 表的外键列不能为not null No action方式:如果子表中有匹配的记录,则不允许对父表对应候选键进行...例如:在员工表中,可以添加一个员工的信息,它的部门指定为一个完全不存在的部门。 问题 3 :那么建和不建外键约束和查询有没有关系?

    24610

    第13章_约束

    ,需要先删除从表中依赖该记录的数据,然后才可以删除主表的数据 (6)在 “从表” 中指定外键约束,并且一个表可以建立多个外键约束 (7)从表的外键列与主表被参照的列名字可以不相同,但是数据类型必须一样,...(根据外键查询效率很高) (9)删除外键约束后,必须 手动 删除对应的索引 # 6.5 添加外键约束 (1)建表时 create table 主表名称( 字段1 数据类型 primary key,...emp引用了,所以部门表的1001字段对应的记录就不能被删除 总结:约束关系是针对双方的 添加了外键约束后,主表的修改和删除数据受约束 添加了外键约束后,从表的添加和修改数据受约束 在从表上建立外键.../delete 掉子表的匹配记录 Set null方式 :在父表上 update/delete 记录时,将子表上匹配记录的列设为 null,但是要注意子表的外键列不能为 not null No...例如:在员工表中,可以添加一个员工的信息,它的部门指定为一个完全不存在的部门。 问题 3:那么建和不建外键约束和查询有没有关系? 答:没有 在 MySQL 里,外键约束是有成本的,需要消耗系统资源。

    39330

    MySQL:表的约束

    6.2 去掉主键 如果想去掉主键: 6.3 建表后添加主键 上面描述的是建表时就在相应数据类型后面表明主键,我们还可以在建表之后再添加主键。...并且建表之后添加主键需要保证在表中需要设置主键的那列元素不能冲突。...像这样主键是有唯一性的,这是没问题的。 如果我插入的元素电话列,发生了冲突,但是主键又只能有一个,所以这里就需要唯一键来约束,保证电话的唯一性。...外键 外键用于定义主表和从表之间的关系:外键约束主要定义在从表上,主表则必须是有主键约束或unique约束。当定义外键后,要求外键列数据必须在主表的主键列存在或为null。...外键需要注意: (1)从表和主表的关联关系 (2)产生外键约束 总结: 好了,到这里今天的知识就讲完了,大家有错误一点要在评论指出,我怕我一人搁这瞎bb,没人告诉我错误就寄了。

    6710

    【数据库设计和SQL基础语法】--SQL语言概述--数据类型和约束

    外键约束有助于维护表之间的关系,确保在引用表中的外键列中的值存在于被引用表的主键列中。...如果需要在已存在的表中添加外键约束,可以使用 ALTER TABLE 语句。...这意味着在插入或更新记录时,必须为这两列提供非空的值。 如果需要在已存在的表上添加非空约束,可以使用 ALTER TABLE 语句。...这个示例展示了如何结合使用不同的数据类型和约束来定义表的结构,确保数据的完整性和一致性。在实际应用中,根据具体需求和业务规则,可以灵活选择和组合适当的数据类型和约束。...这个例子说明了如何使用 ALTER TABLE 语句在表已存在的情况下进行结构的调整,包括添加新列和修改现有列的数据类型以及约束。在实际应用中,修改表结构时需要谨慎操作,尤其是在生产环境中。

    36910

    定义和构建索引(二)

    但是,请注意,对于未定义的属性,不会检查索引的惟一性。 根据SQL标准,未定义的属性总是被视为唯一的。 PrimaryKey -在索引的属性列表中列出的属性上定义一个主键约束。...一般形式是PropertyName(元素)或PropertyName(键),其中该集合的内容是定义为某个数据类型的列表或数组的属性中包含的一组元素)。...第二个参数是通过引用传递的数组。 这是一个包含键-元素对的数组,键下标的数组等于元素。该方法返回一%Status 值。...DescriptiveWords(ELEMENTS);/// 方法的作用是:演示如何在属性的子值上建立索引。...注意:没有必要将任何元素/键值建立在属性值的基础上。 唯一的建议是,每次向该方法传递给定值时,都创建相同的元素和键数组。

    68320

    【重学 MySQL】六十六、外键约束的使用

    它强制子表中的每个记录都引用主表中的一个现有的记录,从而维护数据的一致性和完整性。 外键约束的概念 外键约束是作用于表中字段上的规则,用于限制存储在表中的数据。...数据类型一致:外键中列的数据类型必须和主表主键列的数据类型相同。 外键约束的特点 从表的外键列,必须引用/参考主表的主键或唯一约束的列 为什么?...,然后才可以删除主表的数据 在“从表”中指定外键约束,并且一个表可以建立多个外键约束 从表的外键列与主表被参照的列名字可以不相同,但是数据类型必须一样,逻辑意义一致。...外键约束的约束等级 在MySQL中,外键约束的约束等级决定了当主表中的记录被更新或删除时,子表中相应的外键记录将如何响应。...答:建外键约束,你的操作(创建表、删除表、添加、修改、删除)会受到限制,从语法层面受到限制。例如:在员工表中不可能添加一个员工信息,它的部门的值在部门表中找不到。

    13110

    MySQL约束详接

    从以下四个方面考虑: 什么是约束 约束是表级的强制规定。 可以在创建表时规定约束(通过 CREATE TABLE 语句),或者在表创建之后通过 ALTER TABLE 语句规定约束。  ...一个表可以有很多列都分别限定了非空 空字符串''不等于NULL,0也不等于NULL  添加非空约束 CREATE TABLE 表名称( 字段名 数据类型,   字段名 数据类型 NOT NULL...唯一约束可以是某一个列的值唯一,也可以多个列组合的值唯一。 唯一性约束允许列值为空。在创建唯一约束的时候, 如果不给唯一约束命名,就默认和列名相同。...,也可以是多个字段, #如果是多个字段的话,是复合主键 删除主键约束   自增列:AUTO_INCREMENT 作用 某个字段的值自增 关键字 auto_increment 如何指定自增约束 ...总结:约束关系是针对双方的添加了外键约束后,主表的修改和删除数据受约束添加了外键约束后,从表的添加和修改数据受约束在从表上建立外键,要求主表必须存在删除主表时,要求从表从表先删除,或将从表中外键引用该主表的关系先删除

    1.8K10

    第二十九天-加强1-Junit&类加载&反射&Properties&BeanUtils&xml&动态代理&数据库【悟空教程】

    编写测试类,简单理解Junit可以用于取代java的main方法 2. 在测试类方法上添加注解 @Test 3....17.5 外键约束 FOREIGN KEY 表示外键约束,将在多表中学习。 第18章 多表操作 实际开发中,一个项目通常需要很多张表才能完成。...一对一关系:(了解) 在实际的开发中应用不多.因为一对一可以创建成一张表. 两种建表原则: 外键唯一:主表的主键和从表的外键(唯一),形成主外键关系,外键唯一unique。...18.2 外键约束 现在我们有两张表“分类表”和“商品表”,为了表明商品属于哪个分类,通常情况下,我们将在商品表上添加一列,用于存放分类cid的信息,此列称为:外键 ? ?...声明外键约束 语法:alter table 从表 add [constraint] [外键名称] foreign key (从表外键字段名) references 主表 (主表的主键); [外键名称]

    1.1K70
    领券