我在MySQL Workbench中创建了如下表:

桌上的顺序为:

CREATE TABLE Ordre (
  OrdreID   INT NOT NULL,
  OrdreDato DATE DEFAULT NULL,
  KundeID   INT  DEFAULT NULL,
  CONSTRAINT Ordre_pk PRIMARY KEY (OrdreID),
  CONSTRAINT Ordre_fk FOREIGN KEY (KundeID) REFERENCES Kunde (KundeID)
)
  ENGINE = InnoDB;

产品表:

CREATE TABLE Produkt (
  ProduktID          INT NOT NULL,
  ProduktBeskrivelse VARCHAR(100) DEFAULT NULL,
  ProduktFarge       VARCHAR(20)  DEFAULT NULL,
  Enhetpris          INT          DEFAULT NULL,
  CONSTRAINT Produkt_pk PRIMARY KEY (ProduktID)
)
  ENGINE = InnoDB;

和ORDRELINJE表:

CREATE TABLE Ordrelinje (
  Ordre         INT NOT NULL,
  Produkt       INT NOT NULL,
  AntallBestilt INT DEFAULT NULL,
  CONSTRAINT Ordrelinje_pk PRIMARY KEY (Ordre, Produkt),
  CONSTRAINT Ordrelinje_fk FOREIGN KEY (Ordre) REFERENCES Ordre (OrdreID),
  CONSTRAINT Ordrelinje_fk1 FOREIGN KEY (Produkt) REFERENCES Produkt (ProduktID)
)
  ENGINE = InnoDB;

所以当我尝试插入值到ORDRELINJE表我得到:

错误码:1452。不能添加或更新子行:外键约束失败(srdjank。Ordrelinje_fk外键(order)

我看过其他关于这个话题的帖子,但运气不好。 我是在监督什么事情,还是知道该怎么做?


当前回答

实际上,我就像这样解决了“插入到databasename。Tablename”它起作用了。之后,当我尝试添加数据,如“插入到databasename”它的工作。

其他回答

我也有同样的问题

我把空(")的值为NULL 现在这个“值与父表的id不匹配

这里是需要检查的东西,所有的值都呈现在父表中 否则,从父表中删除数据,然后尝试

对于PhpMyAdmin,转到创建外键的表结构,然后单击关系视图,在其中选择删除和更新部分下的No Action。 注:这个工作适合我。 在这里输入图像描述

您的ORDRELINJE表与ORDER表使用外键约束约束Ordrelinje_fk外键(orderre)引用orderre (orderid)根据orderre int NOT NULL,表ORDRELINJE的列必须匹配任何orderre int NOT NULL, ORDER表的列。

现在在这里发生的是,当你插入新行到ORDRELINJE表,根据fk约束Ordrelinje_fk,它是检查ORDER表,如果OrdreID是存在或不存在,因为它不匹配任何OrderId,编译器抱怨外键违反。这就是您得到这个错误的原因。

外键是另一个表的主键,您可以在任何表中使用它来连接两者。此键由创建表时指定的外键约束绑定。对数据的任何操作都不能违反这个约束。违反这个约束可能会导致这样的错误。

希望我讲清楚了。

只是要找别的东西。如果您必须从一个表中删除记录,并期望值从1开始,那么您可能会得到这个错误。解决方案是在所有父表上运行SHOW * FROM表名。当我这样做的时候,我注意到在其中一个表中,我有一个问题,必须删除一些记录,主键值不是我所期望的,从以前的SELECT *。

我得到这个问题,即使我的父表有我在我的子表中引用的所有值。问题似乎是我不能向一个外键添加多个子引用。换句话说,如果我有5行数据引用了相同的外键,MySQL只允许我上传第一行,并给我错误1452。

对我来说有用的是输入代码“SET GLOBAL FOREIGN_KEY_CHECKS=0”。在那之后,我关闭MySQL,然后重新启动它,我能够上传我所有的数据,没有任何错误。然后我输入“SET GLOBAL FOREIGN_KEY_CHECKS=1”来设置系统恢复正常,尽管我不完全确定FOREIGN_KEY_CHECKS做什么。希望这能有所帮助!