我有一个以user
为主键的表userID
。我有另一个名为Friends
的表。在Friends
表中,我有两个用户作为朋友,由UserID
和FrndID
列表示,其中UserID
和FrndID
应为userID
在表user
中。
我想强制执行数据完整性。我能用这样的东西吗?
ADD CONSTRAINT `ufd_users_fk` FOREIGN KEY (`userId`, `friendId`)
REFERENCES `users` (`userId`, `userId`) ON DELETE CASCADE ON UPDATE CASCADE;
我想知道REFERENCES
个用户(
userId ,
userId )
多次正确引用列?我没有创建2个单独约束的原因是两个用户必须存在于表user
中。
答案 0 :(得分:13)
不,你应该创建两个外键:
ADD CONSTRAINT `ufd_users_fk` FOREIGN KEY (`userId`)
REFERENCES `users` (`userId`)
ON DELETE CASCADE ON UPDATE CASCADE,
ADD CONSTRAINT `ufd_users_fk` FOREIGN KEY (`friendId`)
REFERENCES `users` (`userId`)
ON DELETE CASCADE ON UPDATE CASCADE;