mysql 一个表中的多个外键指向同一个主键

本教程将介绍mysql 一个表中的多个外键指向同一个主键的处理方法,这篇教程是从别的地方看到的,然后加了一些国外程序员的疑问与解答,希望能对你有所帮助,好了,下面开始学习吧。

mysql 一个表中的多个外键指向同一个主键 教程 第1张

问题描述

我有一个 user 表,其中 userID 作为主键.我有另一个名为 Friends 的表.在 Friends 表中,我有两个用户作为朋友,由 UserIDFrndID 列表示,其中 UserIDFrndID 应该是 user 表中的 userID.

我想强制执行数据完整性.我可以使用这样的东西吗?

ADD CONSTRAINT `ufd_users_fk` FOREIGN KEY (`userId`, `friendId`)
REFERENCES `users` (`userId`, `userId`) ON DELETE CASCADE ON UPDATE CASCADE;

我想知道 REFERENCESusers(userId,userId) 是否多次正确引用一列?我没有创建 2 个单独的约束的原因是两个用户都必须存在于表 user 中.

推荐答案

不,你应该创建两个外键:

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;

好了关于mysql 一个表中的多个外键指向同一个主键的教程就到这里就结束了,希望趣模板源码网找到的这篇技术文章能帮助到大家,更多技术教程可以在站内搜索。