Как выбрать два разных значения из таблицы с разными условиями в MySQL? - PullRequest
0 голосов
/ 18 декабря 2018

У меня есть две таблицы:

userdata

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

games

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

Я хочу выбрать имена игроков из одной таблицы пользовательских данных на основе их guid.

Результат, который я пытаюсь получить:

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 

Но как я могу получить второеusername 'username2'?

Ответы [ 3 ]

0 голосов
/ 18 декабря 2018

Вы можете присоединиться дважды.При каждом присоединении к таблице 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;

enter image description here

Демо

0 голосов
/ 18 декабря 2018

Вы можете попробовать ниже - используя объединение нескольких экземпляров таблицы пользовательских данных

 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
0 голосов
/ 18 декабря 2018

Вы можете сделать это, присоединившись к таблице userdata во второй раз.

Примечание. Я использовал современный синтаксис INNER JOIN, чтобы прояснить, к чему применяются предложения join.Я предлагаю вам по возможности использовать современный синтаксис, чтобы сделать ваш код чище и чище.

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
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...