MySQL朋友表

时间:2010-06-09 19:27:16

标签: mysql database-design data-modeling

我有一个MySQL数据库,我在其中存储有关每个用户的数据。

我想为每个用户添加一个好友列表。我应该为数据库中的每个用户创建一个朋友表,还是有更好的方法?

5 个答案:

答案 0 :(得分:9)

假设您的所有朋友也在用户表中,您将需要一个朋友表,该表定义了一个简单的一对多关系 - 将用户表链接回自身。所以

User Table
UserID int identity not null
[other attribute fields]

Friends Table
UserIDLink1 int
UserIDLink2 int 
[other attribute field]

UserIDLink1和UserIDLink2都是Users表上的外键。

例如,如果我有三个用户

1 Joe
2 Bill
3 Jane

和Joe和Jane是朋友,然后Friends表将包含一行

1 3

以上隐含地假设如果A是B的朋友,那么B是A的朋友 - 如果不是这种情况,您可能想要将UserIDLink1和UserIDLink2重命名为UserID和FriendID或类似 - 在这种情况下你的记录也要翻倍。

同样对于双向配置(如果B是A的朋友,A是B的朋友),您应该在Friends表上为(UserIDLink1,UserIDLink2)和(UserIDLink2,UserIDLink1)设置索引以确保访问是如果我们搜索joe的朋友或jane的朋友(如果你没有设置第二个索引,那么第一个查询将是一个有效的索引查找,但第二个将需要一个完整的表扫描)总是有效。

如果您的链接不是双向的,那么就没有必要找出A的朋友是谁,但您可能仍然需要它,因为您可能还需要找出B是谁的朋友。

答案 1 :(得分:7)

假设您的USER表有一个名为id的主键或类似内容,请使用下表:

DROP TABLE IF EXISTS `friends`;
CREATE TABLE `friends` (
  `user_id` int(10) unsigned NOT NULL,
  `friend_id` int(10) unsigned NOT NULL,
  PRIMARY KEY (`user_id`,`friend_id`),
  KEY `FK_FRIENDS_2` (`friend_id`),
  CONSTRAINT `FK_FRIENDS_1` FOREIGN KEY (`user_id`) REFERENCES `users` (`id`),
  CONSTRAINT `FK_FRIENDS_2` FOREIGN KEY (`friend_id`) REFERENCES `users` (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;

这个设置支持彼得是玛丽的朋友,但玛丽并不认为彼得是这样的。但是有数据证明彼得是玛丽的熟人......

两个列的主键也会停止重复。

答案 2 :(得分:1)

您正在寻找M-to-N或多对多联接表。

表用户:

USER_ID  integer primary key,
NAME     varchar

表友谊

USER_ID    integer not null,
FRIEND_ID  integer not null,

USER_ID和FRIEND_ID都是引用Users表(Users.user_id)的外键。

如果用户123是用户921的朋友。将行(123,921)添加到友谊表。

答案 3 :(得分:0)

创建一个包含所有朋友的表格 表格中的每一行都包含用户的ID和他们朋友的ID

答案 4 :(得分:-1)

为所有朋友创建一个表,并为每个朋友提供一个与其各自用户密钥相等的UsersID