以下に示すように、MySQL Workbenchでテーブルを作成しました。
ORDREテーブル:
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;
PRODUKTテーブル:
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
、CONSTRAINTOrdrelinje_fk
FOREIGN KEY(Ordre
)REFERENCESOrdre
(OrdreID
))
このトピックに関する他の投稿を見たことがありますが、運はありません。私は何かをするのか、何をすべきかを監督していますか?