我在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,并将默认值设置为NULL。接下来创建外键关系。之后,您可以更新值以进行相应的匹配

我也有同样的问题

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

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

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

我也有同样的问题。我在现有的表上创建关系,但是有不同的列值,这些列值被认为是相关的。例如,我有一个表USERS,它有一个列USERID,行1、2、3、4、5。然后我有另一个子表ORDERS,列USERID,行1,2,3,4,5,6,7。然后我运行MySQl命令ALTER TABLE ORDERS添加约束ORDER_TO_USER_CONS外键(ORDERUSERID)引用用户(USERID)删除集NULL上更新级联;

被拒绝的理由是:

错误码:1452。不能添加或更新子行:外键约束失败。#sql-4c73_c0,约束ORDER_TO_USER_CONS外键(ORDERUSERID)在删除时引用用户(USERID),在更新级联时设置NULL

我从ORDERS表中导出数据,然后删除其中的所有数据,再次运行该命令,这一次成功了,然后重新插入USERS表中具有相应userid的数据。