Beim Versuch, mehrere Fremdschlüssel hinzuzufügen, wird in SQL ein Fehler angezeigt
Ich versuche, einen Index und mehrere Fremdschlüssel in MySQL zu erstellen, aber wenn ich den folgenden Code einfüge:
CREATE INDEX par_ind on Image_Question (SessionId,QuestionId);
ALTER TABLE Image_Question ADD CONSTRAINT FK_CONSTRAINT_NAME
FOREIGN KEY (SessionId,QuestionId)
REFERENCES Question(SessionId,QuestionId)
ON DELETE CASCADE;
Der Erstellungsindex hat gut funktioniert, aber ich kann die Tabelle nicht ändern und die Fremdschlüssel hinzufügen. Ich gebe mir einen Fehler, der besagt:
#1452 - Cannot add or update a child row: a foreign key constraint fails (`mobile_app`.<result 2 when explaining filename '#sql-4517_14f1a'>, CONSTRAINT `FK_CONSTRAINT_NAME` FOREIGN KEY (`SessionId`, `QuestionId`) REFERENCES `Question` (`SessionId`, `QuestionId`) ON)
Was bedeutet dieser Fehler und wie kann ich diesen Fehler beheben?
Unten ist die Image_Question-Tabelle:
CREATE TABLE Image_Question (ImageQuestionId INT NOT NULL,
ImageId INT NOT NULL,
SessionId CHAR(3) NOT NULL,
QuestionId INT NOT NULL,
PRIMARY KEY (ImageQuestionId)
) ENGINE=INNODB;
Unten ist die Fragentabelle:
CREATE TABLE Question (QuestionId INT NOT NULL,
SessionId CHAR(3) NOT NULL,
Question CHAR(10) NOT NULL ) ENGINE=INNODB;