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

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

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

21.5K21

Mysql外键约束

外键主要用来保证数据的完整性和一致性 两个表必须是InnoDB表,MyISAM表暂时不支持外键 外键列必须建立了索引,MySQL 4.1.2以后的版本在建立外键时会自动创建索引,但如果在较早的版本则需要显示建立...如果父表试图UPDATE或者DELETE任何子表中存在或匹配的外键值,最终动作取决于外键约束定义中的ON UPDATE和ON DELETE选项。...CASCADE: 从父表中删除或更新对应的行,同时自动的删除或更新自表中匹配的行。ON DELETE CANSCADE和ON UPDATE CANSCADE都被InnoDB所支持。 2....SET NULL: 从父表中删除或更新对应的行,同时将子表中的外键列设为空。注意,这些在外键列没有被设为NOT NULL时才有效。...外键约束使用最多的两种情况: 1)父表更新时子表也更新,父表删除时如果子表有匹配的项,删除失败; 2)父表更新时子表也更新,父表删除时子表匹配的项也删除。

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

    hhdb数据库介绍(9-15)

    即在存储节点中,若父表与子表的外键值相等,则可匹配后插入数据,当非分片字段作为外键关联字段时,由于子表外键关联字段路由的节点与父表分片字段的路由节点不一致,导致子表最终路由的存储节点中找不到父表所对应的外键值...,故插入失败:ERROR 1452 (23000): Cannot add or update a child row: a foreign key constraint failsADD SPATIAL...即在存储节点中,若父表与子表的外键值相等,则可匹配后插入数据,但当非关联字段作为外键关联字段时,由于子表外键关联字段路由的节点与父表分片字段的路由节点不一致,导致子表最终路由的存储节点中找不到父表所对应的外键值...即在存储节点中,若父表与子表的外键值相等,则可匹配后插入数据,但当非关联字段作为外键关联字段时,由于子表外键关联字段路由的节点与父表分片字段的路由节点不一致,导致子表最终路由的存储节点中找不到父表所对应的外键值...,故插入失败:ERROR 1452 (23000): Cannot add or update a child row: a foreign key constraint failsFULLTEXT支持

    5410

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

    1.4 特点 从表的外键列,必须引用/参考主表的主键或唯一约束的列 为什么?...但是索引名是外键的约束名 根据外键查询效率很高 删除外键约束后,必须手动删除对应的索引 1.5 添加外键约束 (1)建表时 create table 主表名称( 字段1...,在添加这条记录时,要求部门表有 1001部门 insert into emp values(2,'李四',1005); //添加从表记录失败 ERROR 1452 (23000): Cannot...(外键约束失败) (`atguigudb`....添加了外键约束后,主表的修改和删除数据受约束 添加了外键约束后,从表的添加和修改数据受约束 在从表上建立外键,要求主表必须存在删除主表时,要求从表从表先删除,或将从表中外键引用该主表的关系先删除

    11310

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

    ,在添加这条记录时,要求部门表有 1001 部门 insert into emp values( 2 ,'李四', 1005 );#添加从表记录失败 ERROR 1452 ( 23000 ): Cannot...外键约束失败) (`atguigudb`....添加了外键约束后,主表的修改和删除数据受约束 添加了外键约束后,从表的添加和修改数据受约束 在从表上建立外键,要求主表必须存在 删除主表时,要求从表从表先删除,或将从表中外键引用该主表的关系先删除 6...外键与级联更新适用于单机低并发,不适合分布式、高并发集群;级联更新是强阻塞,存在数据库更新风暴的风险;外键影响数据库的插入速度。 7....添加数据时,没有任何错误或警告 但是 MySQL 8.0中可以使用check约束了 。

    24610

    第13章_约束

    ,在添加这条记录时,要求部门表有1001部门 insert into emp values(2,'李四',1005);#添加从表记录失败 ERROR 1452 (23000): Cannot add(...(外键约束失败) (`atguigudb`....添加了外键约束后,主表的修改和删除数据受约束 添加了外键约束后,从表的添加和修改数据受约束 在从表上建立外键,要求主表必须存在 删除主表时,要求从表从表先删除,或将从表中外键引用该主表的关系先删除...外键与级联更新适用于 单机低并发 ,不适合 分布式 、 高并发集群 ;级联更新是强阻塞,存在数据库 更新风暴 的风险;外键影响数据库的 插入速度 。 # 7....添加数据时,没有任何错误或警告 但是 MySQL 8.0 中可以使用 check 约束了。

    39330

    数据库实验报告

    添加数据时,没有任何错误或警告,但是MySQL 8.0中可以使用check约束了。...四、实验反思: 在实验的过程中,我使用的sqlyog版本并不支持,check约束,我无法添加check约束,在解决这个问题的过程中,我查找这些问题,在他人的博客上,说check约束,在MySQL中只是作为一般的注释...添加数据时,没有任何错误或警告,但是MySQL 8.0中可以使用check约束了。...key: 外键约束,参照完整性 check: 检查约束(MySQL不支持),域完整性 auto_increment: 自增长约束 unsigned: 无符号约束 zerofill: 零填充约束 按照作用的范围来划分...Where子句中的子查询,引用from子句中的表;视图与表的区别视图是从一个或多个表(或视图)导出的虚拟表。

    28010

    【Mysql】:linux环境下表的三部曲(数据操作 + 类型解析 + 约束规则)

    产生外键约束 为什么需要外键约束?...外键 用于 确保表间数据的一致性,例如:防止插入一个不存在班级的学生或删除一个还有学生的班级。 定义:外键约束用于建立主表和从表之间的关联关系,主要定义在从表上,主表必须包含主键或唯一键。...外键 用于定义 主表 和 从表 之间的关系: 外键约束主要定义在从表上 主表则必须是有主键约束或 unique 约束 当定义外键后,要求外键列数据必须在主表的主键列存在或为 NULL 在从表中,设置外键约束...外键 用于 确保表间数据的一致性,例如:防止插入一个不存在班级的学生或删除一个还有学生的班级。 定义:外键约束用于建立主表和从表之间的关联关系,主要定义在从表上,主表必须包含主键或唯一键。...外键 用于定义 主表 和 从表 之间的关系: 外键约束主要定义在从表上 主表则必须是有主键约束或 unique 约束 当定义外键后,要求外键列数据必须在主表的主键列存在或为 NULL 在从表中,设置外键约束

    3700

    MySQL数据库操作教程

    其中数字的长度或者是否有符号位都必须相同 但是,若是字符的长度,则可以不同 */ --4.外键列和参照列必须创建索引,如果外键列不存在索引。!MySQL将自动创建索引!...外键约束的参照操作及功能: 1.CASCADE:从父表删除或更新且自动删除或更新子表中匹配的行 2.SET NULL:从父表删除或更新行,并设置子表中的外键列为NULL (ps.如果使用该选项,...其中数字的长度或者是否有符号位都必须相同 但是,若是字符的长度,则可以不同 */ --4.外键列和参照列必须创建索引,如果外键列不存在索引。!MySQL将自动创建索引!...外键约束的参照操作及功能: 1.CASCADE:从父表删除或更新且自动删除或更新子表中匹配的行 2.SET NULL:从父表删除或更新行,并设置子表中的外键列为NULL (ps.如果使用该选项,...3.子查询的外层查询可以是:SELECT,INSERT,UPDATE,SET或DO。 4.子查询返回值,可以为标量、一行、一列或子查询。

    4.9K10

    MySQL 常见错误代码说明

    7.从库的 Slave_IO_Running 为 NO问题 问题分析:造成从库线程为 NO 的原因会有很多,主要原因是主键冲突或者主库删除或更新数据, 从库找不到记录,数据被修改导致。...通常状态码报错有 1007、1032、1062、1452 等。...145 :文件无法打开 1005:创建表失败 1006:创建数据库失败 1007:数据库已存在,创建数据库失败 1008:数据库不存在,删除数据库失败 1009:不能删除数据库文件导致删除数据库失败 1010...1169:字段值重复,更新记录失败 1177:打开数据表失败 1180:提交事务失败 1181:回滚事务失败 1203:当前用户和数据库建立的连接已到达数据库的最大连接数,请增大可用的数据库连接数或重启数据库...1205:加锁超时 1211:当前用户没有创建用户的权限 1216:外键约束检查失败,更新子表记录失败 1217:外键约束检查失败,删除或修改主表记录失败 1226:当前用户使用的资源已超过所允许的资源

    2.5K50

    MySQL快速入门(二)

    目录 MySQL快速入门(二) 约束条件 自增 自增的特性 主键 外键 级联更新/删除 表与表之间的关系 外键约束 操作表方法 查询关键字 练习数据 select··from where 筛选 group...,那么在mysql中,序号插入失败后台也会记录,比如插入id=1失败了,那么下次就会从2开始记·· 自增不会因为删除操作而回退 delete from 无法影响自增 如果想要重置需需要使用truncate...级联更新/删除 用外键做了表与表的对应关系后,那么操作(增删改)一个表数据,是不允许的; 那么可以通过添加级联更新和删除来同步数据,添加在设置外键下边··· on update cascade:级联更新...table det_info( id int primary key auto_increment, color varchar(32), skill varchar(32) ); 外键约束...在创建表的时候,需要注意先创建没有设置外键的表 在插入数据的时候,要确保被关联表中有数据 在插入新数据的时候,外键字段只能填写被关联表中已经存在的数据 在修改和删除被关联表中的数据的时候,无法直接操作

    2.6K20

    mysql学习总结04 — SQL数据操作

    :结果是一个数据(一行一列) 列子查询:结果是一列(一列多行) 行子查询:结果是一行(一行多列) 表子查询:结果是多行多列(多行多列) exists子查询:返回结果1或0(类似布尔操作) 子查询按位置分类...外键约束概念 外键约束主要约束主表操作,从表仅约束不能插入主表不存在的数据,外键约束约束了例如: 从表插入数据,不能插入对应主表主键不存在的数据 主表删除数据,不能删除被从表引入的数据 外键约束保证了数据的完整性...(主表与从表数据一致),外键强大的数据约束作用可能导致数据在后台变化的不可控,所以外键在实际开发中较少使用 12.5 外键约束模式 三种约束模式: district:严格模式,默认的,不允许操作 cascade...:级联模式,一起操作,主表变化,从表数据跟随变化 set null:置空模式,主表变化(删除),从表对应记录设置为空,前提是从表中对应的外键字段允许为空 添加外键约束模式: 基本语法: add foreign...key(外键字段>) references () on 约束模式>; 通常在进行约束时候的时候,需要指定操作:update和delete 常用的约束模式:on update cascade

    5.2K30

    MySQL学习笔记(长期更新)

    约束类型: 默认约束:插入时如果没有指定值,则插入默认值 主键约束:保证数据的唯一性 外键约束:预防破坏表之间连接的行为 非空约束 :字段值不能为空 唯一性约束:字段值不能重复 自增约束:字段在插入时自动.../image-20210602212346409.png)] 外键约束 从表中定义定义的外键指定外键字段、对应主表中的字段,MySQL会根据外键约束的定义,监控主表中数据的删除操作,如果发现要删除的主表记录...,正在被从表中某条记录的外键字段所引用,MySQL会提示错误,从而保证关联数据不会丢失。...正确使用事务,保证关联操作同时成功或同时失败回滚。...子查询按返回结果集进行分类: 表子查询:返回的结果是一个行的集合,N行N列,(N>=1)。表子查询经常用于父查询的FROM子句中。 行子查询:返回的结果是一个列的集合,一行N列,(N>=1)。

    96310

    MySQL 常见错误代码说明

    7.从库的 Slave_IO_Running 为 NO问题 问题分析:造成从库线程为 NO 的原因会有很多,主要原因是主键冲突或者主库删除或更新数据, 从库找不到记录,数据被修改导致。...通常状态码报错有 1007、1032、1062、1452 等。...145 :文件无法打开 1005:创建表失败 1006:创建数据库失败 1007:数据库已存在,创建数据库失败 1008:数据库不存在,删除数据库失败 1009:不能删除数据库文件导致删除数据库失败 1010...1169:字段值重复,更新记录失败 1177:打开数据表失败 1180:提交事务失败 1181:回滚事务失败 1203:当前用户和数据库建立的连接已到达数据库的最大连接数,请增大可用的数据库连接数或重启数据库...1205:加锁超时 1211:当前用户没有创建用户的权限 1216:外键约束检查失败,更新子表记录失败 1217:外键约束检查失败,删除或修改主表记录失败 1226:当前用户使用的资源已超过所允许的资源

    1.6K21

    MYSQL ERROR CODE 错误编号的意义

    1169:字段值重复,更新记录失败 1177:打开数据表失败 1180:提交事务失败 1181:回滚事务失败 1203:当前用户和数据库建立的连接已到达数据库的最大连接数,请增大可用的数据库连接数或重启数据库...1205:加锁超时 1211:当前用户没有创建用户的权限 1216:外键约束检查失败,更新子表记录失败 1217:外键约束检查失败,删除或修改主表记录失败 1226:当前用户使用的资源已超过所允许的资源...错误:1239 SQLSTATE: 42000 (ER_WRONG_FK_DEF) 消息:对于 ’%s’: %s, 外键定义不正确。...错误:1451 SQLSTATE: 23000 (ER_ROW_IS_REFERENCED_2) 消息:不能删除或更新父行,外键约束失败(%s)。...错误:1452 SQLSTATE: 23000 (ER_NO_REFERENCED_ROW_2) 消息:不能添加或更新子行,外键约束失败(%s)。

    2.9K20

    MySQL 常见的面试题及其答案

    23、如何在MySQL中实现外键约束? MySQL实现外键约束可以使用FOREIGN KEY约束。...MySQL中实现外键约束的方法: 在创建表时,使用FOREIGN KEY约束指定外键,指向另一个表的主键。 外键约束可以在CREATE TABLE或ALTER TABLE语句中指定。...当使用外键约束时,必须使用InnoDB存储引擎。 外键约束可以保证数据的完整性,避免数据丢失或不一致。 如果试图删除具有关联记录的主键,则会拒绝删除操作。...如果试图插入与另一个表中不存在的外键,则会拒绝插入操作。 可以使用CASCADE选项来自动删除或更新具有关联记录的外键记录。 24、什么是MySQL存储引擎?MySQL支持哪些存储引擎?...以下是MySQL支持的一些存储引擎: InnoDB:InnoDB是MySQL的默认存储引擎,它支持事务、行级锁定、外键和崩溃恢复功能。

    7.1K31

    多表间的关系-一对多-多对多-一对一-外键约束

    我们管1的一方,叫主表或1表. 我们管多个一方,叫从表或多表. 通常要在多的一方添加一个字段,用于存放主表主键的值,我们管这个字段叫外键字段....外键字段的值必须为主表主键的值,若为其他值,则没有意义. image-20200529101003797 用于限制外键字段取值必须为主表主键的值的约束叫做-外键约束. 2....外键约束 5.1 什么是外键约束 一张表中的某个字段引用另一个表的主键 主表:约束别人 副表/从表:使用别人的数据,被别人约束 5.2 创建外键 新建表时增加外键:[CONSTRAINT] [外键约束名称...) VALUES ('研发部', '广州'), ('销售部', '深圳'); -- 然后创建员工表,添加外键约束 CREATE TABLE employee ( id INT PRIMARY KEY...> 部门错误的数据添加失败 INSERT INTO employee (NAME, age, dep_id) VALUES ('二王', 20, 5); 执行如下: mysql> select *

    6.2K20

    MYSQL(基本篇)——一篇文章带你走进MYSQL的奇妙世界

    添加外键: -- 创建表时添加外键 CREATE TABLE 表名( 字段名 数据类型, ......外键名称 FOREIGN KEY (外键字段名) REFERENCES 主表(主表列名); 删除外键: ALTER TABLE 表名 DROP FOREIGN KEY 外键名称; 外键约束 外键同样也具有约束条件...: 行为 说明 NO ACTION 当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有则不允许删除/更新。...(与 RESTRICT 一致) 默认行为 RESTRICT 当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有则不允许删除/更新。...(与 NO ACTION 一致) 默认行为 CASCADE 当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有,则 也删除/更新外键在子表中的记录。

    1.7K40

    MySQL 约束

    (foreign key) 1.5.1 概述   外键约束(FOREIGN KEY)是表的一个特殊字段,经常与主键约束一起使用。...对于两个具有关联关系的表而言,相关联字段中主键所在的表就是主表(父表),外键所在的表就是从表(子表)。外键用来建立主表与从表的关联关系,为两个表的数据建立连接,约束两个表中数据的一致性和完整性。...一个表可以有一个或多个外键,外键可以为空值,若不为空值,则每一个外键的值必须等于主表中主键的某个值。定义外键时,需要遵守下列规则:  ♞ 主表必须已经存在于数据库中,或者是当前正在创建的表。...外键名称] foreign key 外键字段 references 关联表(关联字段) ); # 创建后添加 alter table tb_name add [constraint 外键名称] foreign...key 外键字段 references 关联表(关联字段); # 删除外键 alter table tb_name drop foreign key 外键名称; 1.5.3 示例 # 部门表 mysql

    3K31

    PostgreSQL 教程

    完全外连接 使用完全连接查找一个表中在另一个表中没有匹配行的行。 交叉连接 生成两个或多个表中的行的笛卡尔积。 自然连接 根据连接表中的公共列名称,使用隐式连接条件连接两个或多个表。 第 4 节....更新 更新表中的现有数据。 连接更新 根据另一个表中的值更新表中的值。 删除 删除表中的数据。 连接删除 根据另一个表中的值删除表中的行。 UPSERT 如果新行已存在于表中,则插入或更新数据。...添加列 向您展示如何向现有表添加一列或多列。 删除列 演示如何删除表的列。 更改列数据类型 向您展示如何更改列的数据。 重命名列 说明如何重命名表中的一列或多列。...了解 PostgreSQL 约束 主题 描述 主键 说明在创建表或向现有表添加主键时如何定义主键。 外键 展示如何在创建新表时定义外键约束或为现有表添加外键约束。...检查约束 添加逻辑以基于布尔表达式检查值。 唯一约束 确保一列或一组列中的值在整个表中是唯一的。 非空约束 确保列中的值不是NULL。 第 14 节.

    59210
    领券