0

我的系统使用一个用户表,其中包含多个元素,包括他们的在线状态。现在我想添加一个功能,以便每个用户都可以将联系人(即数据库中的现有用户)添加到他们的朋友或联系人列表中,以显示他们的姓名和在线状态。但是,我需要在线状态的任何更改以在联系人列表中更新,因此创建新表无济于事。

我一直在研究这方面的观点,但对数据库没有太多经验,我想知道这是否是正确的方法,以及如何做的更多细节。

以下是我正在考虑的步骤:

  1. 当用户注册时,创建一个视图即view_name = username_view。
  2. 要添加联系人,请从主用户表中选择数据并添加到用户视图
  3. 要删除联系人,请从视图中删除选定的数据。

我不确定这是否可以通过视图实现,所以如果不能,请帮助我。

谢谢。

4

1 回答 1

0

ER 数据库 = 实体和关系数据库通过有一个包含实体“用户”的表和一个用于将用户连接到另一个用户的关系“朋友”的表来处理它。

对此的查询可以是:

SELECT users.* 
FROM friends 
LEFT JOIN users ON (users.user_id = friends.friend_id) 
WHERE friends.user_id = :user

示例:

用户表,用于实体用户

CREATE TABLE user (user_id SERIAL, name TINYTEXT NOT NULL);

示例用户

user_id | name
      1 | Anna
      2 | Bertil
      3 | Carl
      4 | David
      5 | Erik

一个朋友表,用于两个用户之间的关系,(不是每个用户一个,只有一个)

CREATE TABLE friends (
  user_id BIGINT UNSIGNED NOT NULL,
  friend_id BIGINT UNSIGNED NOT NULL,
  PRIMARY KEY (user_id, friend_id)
);

如果 Anna 将 Beril 和 Carl 添加为好友,Carl 添加 David 和 Erik 作为好友,则表格的内容将是:

user_id | friend_id
      1 |         2
      1 |         3
      3 |         4
      3 |         5

如果我们想列出 Annas 朋友的名字,并且我们都知道 Annas user_id = 1,那么我们可以使用这个查询(就像上面的那个)

SELECT users.name 
FROM friends 
LEFT JOIN users ON (users.user_id = friends.friend_id) 
WHERE friends.user_id = 1
于 2012-06-30T18:29:06.813 回答