我有两张桌子:
-
g_关系(id、请求id、接收者id、状态、已批准)
-
g_用户(包含:id、用户名等)
我很难做一个查询,添加一个临时列,检查userid:4是否存在于request_id或receiver_id列中,并从g_用户获取另一个userid和username,并将其添加到临时列中。
例如:假设我有userid 4。然后,我想选择g_关系,左键连接g_用户,并添加一列,检查我的用户id(4)是在request_id还是receiver_id列中,并获取不是我的用户id,检查它是哪个用户名,并用它填充新列。
例如:正确的结果如下:(如果我收到一个朋友请求)
身份证件
|
请求\u id
|
接收机识别码
|
地位
|
经核准的
|
朋友(新专栏)
|
1.
|
3.
|
4.
|
朋友
|
不
|
尼奥
|
但如果是我发出朋友请求的话,情况会是这样的
身份证件
|
请求\u id
|
接收机识别码
|
地位
|
经核准的
|
朋友(新专栏)
|
1.
|
4.
|
3.
|
朋友
|
不
|
尼奥
|
换句话说,查询应该始终检查我没有出现的列,并获取该用户ID,对照g_users表进行检查,然后将用户名从那里放入friend列。
这是我到目前为止的想法,但这只会检查然后请求_id不是4,也不会用用户名填充临时列“friend”:/
SELECT *, ("friend" = CASE WHEN request_id != 4 THEN END) as friend_id
FROM `g_relationships`
LEFT JOIN g_users
ON g_relationship.request_id = g_users.id
WHERE request_id = 4 OR receiver_id = 4
AND status = "friend"
AND approved = "no"
有什么建议吗?