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

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


当前回答

我发现,在我尝试做我知道是正确的代码之前,将外键从非空改为空。帮助我使用Mysql工作台。我还必须设置set FOREIGN_KEY_CHECKS=0;然后回到=1;后完成。

其他回答

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

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

我也有同样的问题

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

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

您应该在每个表中插入至少一个raw(您希望外键指向的表),然后您可以插入或更新外键的值

在阅读@ mr . faizan和其他回答后,这帮助了我。

取消“启用外键检查”

在phpMyAdmin中点击查询。 我不了解WorkBench,但其他答案可能会帮助您。

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