mysql表中的多个外键到同一主键

时间:2013-09-17 00:46:45

标签: mysql sql foreign-keys primary-key referential-integrity

我有一个以user为主键的表userID。我有另一个名为Friends的表。在Friends表中,我有两个用户作为朋友,由UserIDFrndID列表示,其中UserIDFrndID应为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中。

1 个答案:

答案 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;