MySQL 中的外键约束错误:“错误 1452:无法添加或更新子行”
在向子表插入数据时,外键约束确保父表中引用的数据存在。但是,如果违反此约束,则会发生错误,如下面的查询所示:
<code class="language-sql">INSERT INTO Ordrelinje (Ordre, Produkt, AntallBestilt) VALUES (100, 1, 5);</code>
理解错误
错误“错误 1452:无法添加或更新子行:外键约束失败”表明,父表中没有与指定外键值匹配的行。在本例中,没有 OrderID 为 100 的 Ordre。
解决问题
要解决此错误,您必须首先确保父表中存在引用的数据:
<code class="language-sql">INSERT INTO Ordre (OrdreID, KundeID) VALUES (100, 200);</code>
一旦父表具有必要的数据,您就可以在不遇到外键约束错误的情况下向子表插入数据:
<code class="language-sql">INSERT INTO Ordrelinje (Ordre, Produkt, AntallBestilt) VALUES (100, 1, 5);</code>
外键关系
外键关系在表之间建立链接,确保数据完整性并防止数据操纵异常。子表包含一个引用父表中列的列,从而创建父子关系。
强制外键约束
默认数据库设置通常强制执行外键约束。如果发生违规,数据库将不允许数据操纵操作继续进行。
以上是MySQL 外键约束错误 1452:如何修复'无法添加或更新子行”?的详细内容。更多信息请关注PHP中文网其他相关文章!