2015-05-15 88 views
-1

我已经创建了几个表,其中一个是父表和三个子表。MySQL外键:无法添加或更新子行:外键约束失败

CREATE TABLE `members` (
`memberID` int(11) NOT NULL AUTO_INCREMENT, 
`username` varchar(255) NOT NULL, 
`password` varchar(60) NOT NULL, 
PRIMARY KEY (`memberID`) 
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=latin1 

CREATE TABLE `pets` (
`petsID` int(11) NOT NULL AUTO_INCREMENT, 
`Gender` varchar(25) NOT NULL, 
`Age` varchar(25) NOT NULL, 
`Size` varchar(25) NOT NULL, 
`memberID` int(11) NOT NULL, 
PRIMARY KEY (`petsID`), 
KEY `fk_pets` (`memberID`), 
CONSTRAINT `pets_ibfk_1` FOREIGN KEY (`memberID`) REFERENCES `members` (`memberID`) ON DELETE CASCADE ON UPDATE CASCADE 
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=latin1 

CREATE TABLE `owner` (
`ownerID` int(11) NOT NULL AUTO_INCREMENT, 
`nameOwner` varchar(25) NOT NULL, 
`ageOwner` varchar(25) NOT NULL, 
`bioOwner` varchar(800) NOT NULL, 
`memberID` int(11) NOT NULL, 
PRIMARY KEY (`ownerID`), 
KEY `fk_owner` (`memberID`), 
CONSTRAINT `owner_ibfk_1` FOREIGN KEY (`memberID`) REFERENCES `members` (`memberID`) ON DELETE CASCADE ON UPDATE CASCADE 
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=latin1 

CREATE TABLE `service` (
`serviceID` int(11) NOT NULL AUTO_INCREMENT, 
`nameService` varchar(25) NOT NULL, 
`webService` varchar(25) NOT NULL, 
`memberID` int(11) NOT NULL, 
PRIMARY KEY (`serviceID`), 
KEY `fk_service` (`memberID`), 
CONSTRAINT `service_ibfk_1` FOREIGN KEY (`memberID`) REFERENCES `members` (`memberID`) ON DELETE CASCADE ON UPDATE CASCADE 
) ENGINE=InnoDB DEFAULT CHARSET=latin1 

测试出我的桌子后,我收到了此错误:

INSERT INTO owner (nameOwner, ageOwner, bioOwner) VALUES ('', '', '') 
Cannot add or update a child row: a foreign key constraint fails (`DB`.`owner`, CONSTRAINT `owner_ibfk_1` FOREIGN KEY (`memberID`) REFERENCES `members` (`memberID`) ON DELETE CASCADE ON UPDATE CASCADE) 

我已经尝试过截断我的父表,但它仍然有这个错误出现。我在数据库设计的初学者,所以请解释一下像我5.

+2

确定 - 就像你五岁那样:你正试图在没有可引用父代的子行中插入一行。 –

+0

@HoboSapiens有一些非常错误的“OK - 就像你是五...” – Ajoy

+1

@Ajoy - 我只是在他自己的要求中强制OP。读他最后一句话。 –

回答

0
CONSTRAINT `owner_ibfk_1` FOREIGN KEY (`memberID`) REFERENCES `members` (`memberID`) 

在主表此约束意味着,在该表的每一行需要有一个有效的memberID。如果它存在于members表的memberID列中,则仅考虑有效

insert声明:

INSERT INTO owner (nameOwner, ageOwner, bioOwner) VALUES ('', '', '') 

提供一个memberID要插入所以无论正在使用显然不是在members表。因此违反约束。

最简单的修复方法是在您的insert声明中提供有效的memberID声明,该声明已存在于members中。

通过举例的方式,这会工作,假设你还没有一个42members

insert into members (memberID, username, password) values (
    42, 
    'paxdiablo', 
    'never_you_mind'); 
insert into owner (nameOwner, ageOwner, bioOwner, memberID) values (
    'Pax Diablo', 
    'too damn old', 
    'no idea what this should be', 
    42); 

如果你不知道会员ID应该是什么,你可以使用类似:

insert into owner (nameOwner, ageOwner, bioOwner, memberID) 
    select 'Pax Diablo', 
      'too damn old', 
      'no idea what this should be', 
      memberID 
     from members where username = 'paxdiablo'; 

虽然你可能想members.memberID是唯一的。


实际发生的位置取决于MySQL版本,您正在使用,以及是否它的运行严格SQL模式与否。我想从内存中,它会或者失败insert或使用零作为默认值。

+0

那么我必须编辑插入语句到INSERT INTO所有者(nameOwner,ageOwner,bioOwner,memberID)VALUES('xx','xx','xx','')?我会像上面介绍的那样保持VALUE空吗?感谢您的帮助btw,我真的很感激它。 – laimingl

+0

@laimingl,这只有在'members'表中有''''的成员id时才会起作用,并且它会将所有插入链接到该行。这不太可能是你想要的。相反,你需要在'members'中找到正确的记录,并用其他数据将'memberID'插入'owner'。 – paxdiablo

相关问题