我在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)

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


当前回答

在插入外键属性值时,首先验证属性类型,以及父关系中的主键属性值,如果父关系中的值匹配,那么就可以轻松地插入/更新子属性值。

其他回答

出现此问题是因为在子表中插入一些数据后在子表中设置了外键。

尝试从子表中删除所有数据,然后设置外键,然后在表中添加/插入数据,它将工作。

这可以通过先在父表中插入各自的记录,然后在子表的各自列中插入记录来解决。还要检查列的数据类型和大小。它应该与父表列相同,甚至引擎和排序规则也应该相同。 试试这个!这就是我解决问题的方法。如果我说错了,请指正。

您得到这个约束检查是因为orderre表没有插入命令中提供的引用orderid。

要在Orderlinje中插入值,首先必须在orderre表中输入值,并在Orderlinje表中使用相同的orderid。

或者您可以删除非空约束,并在其中插入一个null值。

当使用外键时,插入的列顺序应该相同。

例如,如果你从table2中添加(userid, password)到table1中,那么从table2中添加(userid, password)的顺序应该是相同的(userid, password),而不是(password,userid),其中userid是table1的table2中的外键。

取自使用外键约束

外键关系涉及一个父表,该表保存 中心数据值,以及具有相同值指向的子表 回到它的父节点。FOREIGN KEY子句在子句中指定 表格 它将拒绝尝试创建的任何INSERT或UPDATE操作 子表中没有匹配的外键值 父表中的候选键值。

所以你的错误错误码:1452。不能添加或更新子行:外键约束失败本质上意味着,您试图向orderrelinje表添加一行,而orderre表中没有匹配的行(OrderID)。

您必须首先将行插入到orderre表中。