在mysql中,如何从一个条件不同的表中选择两个不同的值?

kmbjn2e3  于 2021-06-15  发布在  Mysql
关注(0)|答案(3)|浏览(323)

我有两张table:

userdata

guidUser  username  
-----------------
12        plr1        
13        plr2
14        plr3
15        plr4

games

id  guidUser1  guidUser2
-------------------------
1       12        13
2       15        14

我想根据玩家的guid从同一个userdata表中选择玩家的名字。
我想要得到的结果是:

id  guidUser1   username  guidUser2  username2
--------------------------------------------
1       12        plr1        13        plr2
2       15        plr4        14        plr3

如果这个值是我唯一能做的

SELECT g.id, g.guidUser1, u.username, g.guidUser2 from games g, userdata u WHERE g.guidUser1=u.guidUser1

但是我怎样才能获得第二个用户名'username2'?

nhn9ugyo

nhn9ugyo1#

你可以参加两次。每个加入 userdata 表中包含一个用户名:

SELECT
    g.id,
    g.guidUser1,
    u1.username,
    g.guidUser2,
    u2.username AS username2
FROM games g
INNER JOIN userdata u1
    ON g.guidUser1 = u1.guidUser
INNER JOIN userdata u2
    ON g.guidUser2 = u2.guidUser;

演示

5uzkadbs

5uzkadbs2#

您可以在下面尝试-使用userdata表的多个示例的连接

SELECT g.id, g.guidUser1, u.username, g.guidUser2 u1.username as username2
    from 
    games g inner join userdata u on g.guidUser1=u.guidUser
    inner join userdata u1 on g.guidUser2=u1.guidUser
myss37ts

myss37ts3#

您可以通过第二次加入userdata表来完成。
注意,我使用了现代的内部连接语法,以便更清楚地说明连接子句适用于什么。我建议您尽可能地使用现代语法,使您的代码更清晰。

SELECT 
  g.id, 
  g.guidUser1, 
  u1.username AS username1, 
  g.guidUser2,
  u2.username AS username2
FROM
  games g 
  INNER JOIN userdata u1
    ON g.guidUser1 = u.guidUser
  INNER JOIN userdata u2
    ON g.guidUser2 = 2.guidUser

相关问题