这是一个非常普遍的问题,我尚未找到解决方案,也没有找到在线解决方案,而且我已经搜索了几天(如果有人知道,只需给我链接将不胜感激)。
我已经使用MySQL Workbench,带有wamp的服务器创建了一个数据库,并打算使用netbeans ide 8.0为我的项目创建一个php应用程序。
我的问题是我无法在“子”表中添加数据(对不起,这个词不准确)。下面的代码来自MySQL Workbench的“来自eer模型的正向工程sql代码”,并且仅将其中一个子表视为问题:
CREATE TABLE IF NOT EXISTS `ASTIR`.`HOTEL` (
`ID` INT NOT NULL,
`NAME` VARCHAR(45) NOT NULL,
`STREET` VARCHAR(45) NULL,
`No` INT NULL,
`ΤΚ` INT NULL,
`CITY` VARCHAR(45) NULL,
`RATING` SMALLINT NULL,
`YEAR OF CONSTRUCTION` YEAR NULL,
`YEAR OF RENOVATION` YEAR NULL,
PRIMARY KEY (`ID`))
ENGINE = InnoDB;
CREATE TABLE IF NOT EXISTS `ASTIR`.`ROOM` (
`HOTEL_ID` INT NOT NULL,
`ROOM_No` INT NOT NULL,
`TYPE` VARCHAR(45) NOT NULL,
`PRICE` DOUBLE NOT NULL,
PRIMARY KEY (`HOTEL_ID`, `ROOM_NO`),
INDEX `fk_ROOM_HOTEL1_idx` (`HOTEL_ID` ASC),
CONSTRAINT `fk_ROOM_HOTEL1`
FOREIGN KEY (`HOTEL_ID`)
REFERENCES `ASTIR`.`HOTEL` (`ID`)
ON DELETE NO ACTION
ON UPDATE NO ACTION)
ENGINE = InnoDB;
所以,当我键入命令
INSERT INTO ROOM(HOTEL_ID,ROOM_No,TYPE,PRICE) VALUES(1,1,'SUITE',55);
我收到消息
Error Code: 1452. Cannot add or update a child row: a foreign key constraint fails (`ASTIR`.`ROOM`, CONSTRAINT `fk_ROOM_HOTEL1` FOREIGN KEY (`HOTEL_ID`) REFERENCE)
任何想法都会有所帮助,非常感谢:/
最佳答案
该错误意味着HOTEL
表中没有id = 1的行。
您需要先插入父(HOTEL
)行,然后才能插入子(ROOM
)行。
INSERT INTO HOTEL(ID,NAME) VALUES(1,'First Hotel');
INSERT INTO ROOM(HOTEL_ID,ROOM_No,TYPE,PRICE) VALUES(1,1,'SUITE',55);