1.检查两个字段的数据类型是否一致 2.检查两个字段的数据长度是否一致(有时候不指定int长度,长度是10,有时候是11)
本文为作者翻译文章,原文链接:Dealing with MySQL Error Code 1215: “Cannot add foreign key constraint” 在给一个表创建外键时,MySQL...总是会出现提示: ERROR 1215 (HY000): Cannot add foreign key constraint 这信息基本是啥都没说,下面就来说说几种常见的导致1215错误的情况: 父表不存在...(HY000): Cannot add foreign key constraint mysql> SHOW TABLES LIKE 'par%'; Empty set (0.00 sec) 解决方法...parent_virt INT(10) NOT NULL, FOREIGN KEY (parent_virt) REFERENCES parent(column_virt) ) ENGINE INNODB; 创建外键失败的更多提示信息...(HY000): Cannot add foreign key constraint mysql>show engine innodb status\G .... ------------------
· 错误:1215 SQLSTATE: HY000 (ER_CANNOT_ADD_FOREIGN) 消息:无法添加外键约束。...· 错误:1216 SQLSTATE: 23000 (ER_NO_REFERENCED_ROW) 消息:无法添加或更新子行,外键约束失败。...· 错误:1217 SQLSTATE: 23000 (ER_ROW_IS_REFERENCED) 消息:无法删除或更新父行,外键约束失败。...· 错误:1452 SQLSTATE: 23000 (ER_NO_REFERENCED_ROW_2) 消息:不能添加或更新子行,外键约束失败(%s)。...· 错误:1493 SQLSTATE: HY000 (ER_DROP_PARTITION_WHEN_FK_DEFINED) 消息:在表上定义了外键约束时,不能舍弃分区。
1181:回滚事务失败 1203:当前用户和数据库建立的连接已到达数据库的最大连接数,请增大可用的数据库连接数或重启数据库 1205:加锁超时 1211:当前用户没有创建用户的权限 1216:外键约束检查失败...,更新子表记录失败 1217:外键约束检查失败,删除或修改主表记录失败 1226:当前用户使用的资源已超过所允许的资源,请重启数据库或重启服务器 1227:权限不足,您无权进行此操作 1235:...错误: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)。
什么是外检约束 外键其实很好理解,简单的说就是两张表建立一个连接关系。这里我们那主表A和副表B举例,我A表中有用户信息,B表中有用户订单信息。...要是数据完整对应起来,肯定是需要把两张表关联起来,我们因此会在B表中村一个A表的字段,常见的我们存的是A表的主键ID外键。 外检约束要求 .MySQL的数据表存储引擎必须为Innodb。...外键约束的作用 保证数据的完整性和一致性. 创建语法 [CONSTRAINT [symbol]] FOREIGN KEY [index_name] (index_col_name, ...)...SET NULL: 从父表中删除或更新对应的行,同时将子表中的外键列设为空。注意,这些在外键列没有被设为NOT NULL时才有效。...(HY000): Cannot add foreign key constraint 结论:Innodb存储引擎暂不支持。
在库存表中添加一条库存记录。...,如果大于领导薪资,则报sqlstate_value为'HY000'的错误,从而使得添加失败。...'HY000' SET MESSAGE_TEXT = '薪资高于领导薪资错误'; END IF; END // DELIMITER ; 上面触发器声明过程中的NEW关键字代表INSERT添加语句的新记录...注意点 注意,如果在子表中定义了外键约束,并且外键指定了ON UPDATE/DELETE CASCADE/SET NULL子句,此时修改父表被引用的键值或删除父表被引用的记录行时,也会引起子表的修改和删除操作...例如:基于子表员工表(t_employee)的DELETE语句定义了触发器t1,而子表的部门编号(did)字段定义了外键约束引用了父表部门表(t_department)的主键列部门编号(did),并且该外键加了
,如果大于领导薪资,则报 sqlstate_value 为’HY000’的错误,从而使得添加失败。...'HY000' SET MESSAGE_TEXT = '薪资高于领导薪资错误'; END IF; END // DELIMITER ; 上面触发器声明过程中的 NEW 关键字代表 INSERT 添加语句的新记录...# 4.3 注意点 注意,如果在子表中定义了外键约束,并且外键指定了 ON UPDATE/DELETE CASCADE/SET NULL 子句,此时修改父表被引用的键值或删除父表被引用的记录行时,也会引起子表的修改和删除操作...例如:基于子表员工表(t_employee)的 DELETE 语句定义了触发器 t1,而子表的部门编号(did)字段定义了外键约束引用了父表部门表(t_department)的主键列部门编号(did),...并且该外键加了 “ON DELETE SET NULL” 子句,那么如果此时删除父表部门表(t_department)在子表员工表(t_employee)有匹配记录的部门记录时,会引起子表员工表(t_employee
KEY :主键,指定该列的值可以唯一地标识该列记录 # FOREIGN KEY :外键,指定该行记录从属于主表中的一条记录,主要用于参照完整性 返回顶部 NOT NULL 是否可空,null表示空,非字符串...| +---------+--------------+------+-----+---------+-------+ rows in set (0.01 sec) # 方法四:给已经建成的表添加主键约束...(HY000): Cannot add foreign key # 设置dep_id非空,仍然不能成功创建外键 mysql> alter table departments modify dep_id...(HY000): Cannot add foreign key constraint # 当设置字段为unique唯一字段时,设置该字段为外键成功 mysql> alter table departments...Restrict方式 同no action, 都是立即检查外键约束 . Set default方式 父表有变更时,子表将外键列设置成一个默认的值 但Innodb不能识别
引言: MySQL中经常会需要创建父子表之间的约束,这个约束是需要建立在主外键基础之上的,这里解决了一个在创建主外键约束过程中碰到的一个问题。 1....碰到错误 在创建外键之时,使用的SQL和碰到错误信息如下: alter table `product' add CONSTRAINT `sid_ref` FOREIGN KEY (`sid`)...REFERENCES `sealer` (`id`) ON DELETE NO ACTION ON UPDATE NO ACTION 碰到的错误信息如下: 无法正确的插入外键约束。...解决的办法 修改product.sid中的数据类型,添加unsigned和字段的长度,将其设置为相同即可。 5....总结 之所以出现1215的问题,是由于主外键之间的数据类型不一致造成的,以后类似问题,皆可按此处理。
23503 外键的插入或更新值无效。23504 NO ACTION 更新或删除规则防止父键被更新或删除。23505 发生由唯一索引或唯一约束强加的约束违例。...23510 使用由 RLST 表强加的命令时发生约束违例。23511 不能删除父行,因为检查约束限制该删除。23512 不能添加检查约束,因为该表含有不满足约束定义的行。...23513 INSERT 或 UPDATE 的结果行不符合检查约束定义。23514 检查数据处理中发现约束违例。23515 未能创建唯一索引,或者不能添加唯一约束,因为该表包含指定键的重复值。...23520 不能定义外键,因为其所有的值都不同于父表的父键。23521 对目录表的更新违反了内部约束。23522 标识列值的范围或者序列用完。23523 已经为安全标号列提供了无效值。...42830 外键不符合父键的描述。 42831 主键或唯一键列不允许空值。 42832 不允许对系统对象执行该操作。 42834 不能指定 SET NULL,因为不能对外键的任何列指定空值。
; signal sqlstate 'HY000' set message_text=msg; end if; end; $$ delimiter ; delimiter解释:其实就是告诉...2.2 外键 2.2.1 创建外键 (1)不带别名的外键,数据库自动生成 首先创建department表: CREATE TABLE department ( dept_name varchar...(2)删除外键 alter table instructor drop foreign key fk_dept_name; (3)添加外键 alter table instructor add constraint...学习 cascade 表示级联操作,就是说,如果主键表中被参考字段更新,外键表(子表)中也更新,主键表(父表)中的记录被删除,外键表(子表)中改行也相应删除。...而on update只能删除子表外键数据,不能删除父表主键数据,只能更新父表的主键,同时父子表数据都会被更新,但是在子表的外键上做更新操作无效。
一、表的约束 在创建表的时候,可以给表的字段添加相应的约束,添加约束的目的是为了保证表中数据的合法性、有效性、完整性。...(简称PK) 外键约束(foreign key):…(简称FK) 检查约束(check):注意Oracle数据库有check约束,但是mysql没有,目前mysql不支持该约束。...username varchar(255) ); 外键约束:foreign key 外键主要是维护表之间的关系的,主要是为了保证参照完整性,如果表中的某个字段为外键 字段,那么该字段的值必须来源于参照的表的主键...外键可以为NULL 被外键引用的字段不一定是主键,但至少具有unique约束。...InnoDB 优点:支持事务、行级锁、外键等。这种存储引擎数据的安全得到保障。
(根据外键查询效率很高) (9)删除外键约束后,必须 手动 删除对应的索引 # 6.5 添加外键约束 (1)建表时 create table 主表名称( 字段1 数据类型 primary key,...添加了外键约束后,主表的修改和删除数据受约束 添加了外键约束后,从表的添加和修改数据受约束 在从表上建立外键,要求主表必须存在 删除主表时,要求从表从表先删除,或将从表中外键引用该主表的关系先删除...答:不是的 问题 2:建和不建外键约束有什么区别? 答:建外键约束,你的操作(创建表、删除表、添加、修改、删除)会受到限制,从语法层面受到限制。...例如:在员工表中,可以添加一个员工的信息,它的部门指定为一个完全不存在的部门。 问题 3:那么建和不建外键约束和查询有没有关系? 答:没有 在 MySQL 里,外键约束是有成本的,需要消耗系统资源。...添加数据时,没有任何错误或警告 但是 MySQL 8.0 中可以使用 check 约束了。
外键约束 添加外键约束 删除外键约束 阿里开发规范 约束等级 CHECK约束检查 DEFALUT默认值约束 添加默认值约束 删除默认值约束 关于默认值的面试题 关于约束的开发建议 十八、视图 常用的数据库对象...总结:约束关系是针对双方的 添加了外键约束后,主表的修改和删除数据受约束。 添加了外键约束后,从表的添加和修改数据受约束。 在从表上建立的外键,要求主表必须存在。...例如,在ERROR 1418 (HY000)中,1418是MySQL_error_code,'HY000’是sqlstate_value。...则报sqlstate_value为'HY000'的错误,从而使得添加失败。...SIGNAL SQLSTATE 'HY000' SET MESSAGE_TEXT = '薪资高于领导薪资错误'; END IF; END // DELIMITER ; 查看、删除触发器 查看触发器
(例外:一个临时表可能使用与非临时表一样的约束名称) CHECK的条件表达式必须遵守以下规则,如果包含不允许的结构,将会触发错误: 非生成列和生成列允许被添加到表达式,但包含AUTO_INCREMENT...(),CURRENT_USER(),NOW() 存储函数和用户自定义函数不被允许 存储过程不被允许 变量:系统变量、用户自定义变量和存储过程的本地变量均不被允许使用 子查询不应许被使用 外键参考动作,如...:ON UPDATE, ON DELETE被禁止在包含CHECK约束的列使用,相应的,CHECK约束也被禁止在使用外键参考动作的列使用 CHECK约束在插入、更新、替换(REPLACE)和LOAD DATA.../XML语句的时候被评估,如果评估结果是FALSE将触发错误,如果错误发生,已经提交的数据的处理与对应存储引擎是否支持事务有关,也依赖严格SQL模式是否生效 如果约束表达式所需的数据类型与声明的列类型不一致...CHECK (ID>=1 AND PID >=0); -- remove check ALTER TABLE Departments DROP CHECK CHK_PID; 如果属于数据库逻辑,比如:审计,外键可以使用触发器
,但是换到mysql的时候,无法成功创建外键。...手动执行添加外键也无法成功 手动执行sql语句 ALTER TABLE datasync_monitor.table_monitor_strategy ADD CONSTRAINT fk_account_table...: 1215 Cannot add foreign key constraint 既然liquibase能够在h2上成功创建表以及外键,但是在mysql上创建不了,而且表存在手动也不能添加外键,估计就是...Mysql添加不了外键原因有三: (1)外键对应的字段数据类型不一致 (2)两张表的存储引擎不一致 (3)设置外键时“删除时”设置为“SET NULL” 一个个排除,发现table_monitor_strategy...这张表对应account_monitor_strategy这张表的外键字段是设计成varchar类型的,而account_monitor_strategy中的id是bigint型的,所以才会出现无法创建外键的问题
mysql有哪些外键约束等级 1、Cascade方式。 当update/delete记录在主表上时,同步update/delete掉从表的匹配记录。 2、Set null方式。...如果子表中有匹配记录,则不允许update/delete操作与父表相对应的候选键。 4、Restrict方法,与no action相同。 立即检查外键约束。...当父表发生变化时,子表将外键列设置为默认值,但Innodb无法识别。...eid int primary key, name varchar(50) not null, sex varchar(10), dept_id int ); -- 给员工表表的dept_id添加外键指向部门表的主键...alter table emp add foreign key(dept_id) references dept(id) 以上就是mysql外键约束等级的介绍,希望对大家有所帮助。
如果表的任何行的搜索条件的结果为 FALSE,则约束可能返回错误(但如果结果为 UNKNOWN 或 TRUE,则约束不会返回错误)。...要牢记的使用规则: AUTO_INCREMENT 自增列不允许使用 引用另一个表中的另一列不允许使用 存储的函数和用户定义的函数不允许使用 存储过程和函数参数不允许使用 子查询不允许使用 在外键中用于后续操作...要删除,请使用下一个示例: ALTER TABLE users DROP CHECK check_1; 让我们看另一个示例,向其中添加更多逻辑。...如您在 ERROR 消息中所见,MySQL 正在显示 CHECK 约束名称。可以从应用程序源代码中使用它来调试错误并知道从哪个 CHECK 失败。...,但是根据我以前作为程序员的经验,我不建议在表中添加逻辑,因为除非您无法访问应用程序代码,否则很难找到或调试错误。
如: - 实体完整性 - 用户定义完整性 - 参照完整性 只有当某个字段成为了主键后,该字段才能在其它表中成为外键。...将t_test1表中id字段设为主键,t_test2表中id字段设为外键。...外键约束(foreign key):......password varchar(255) ); insert into t_user(id,password) values(1,'123'); //编译错误,约束username字段不能为空!...1.15.5 外键约束 关于外键约束的相关术语: 外键约束:foreign key 外键字段:添加有外键约束的字段 外键值:外键字段中的每一个值。
AppServiceProvider 内注册某模型的观察者: public function boot() { User::observe(UserObserver::class); } 然后添加观察者类...不推荐的方法 还有一种方法,我们本不打算推荐,但是考虑到有的初学者容易犯此类错误,就拿出来最为参照。 程序功能应该单一。比如,尽量避免把数据关联操作放到数据库执行。...MySQL提供了外键约束,并且可以定义触发器用于批次动作处理。...那么使用 Laravel migrations 时,创建photo表的外键关联事件: $table->foreign('user_id')->references('id')->on('users')-...写在最后 本文通过3种方式,实现了Laravel中关联删除表记录的功能。
领取专属 10元无门槛券
手把手带您无忧上云