Как выбрать два разных значения из таблицы с разными условиями в mysql?

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

userdata

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

games

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

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

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

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?

Вы пробовали присоединиться к userdata?

Nico Haase 18.12.2018 15:03
Освоение архитектуры микросервисов с Laravel: Лучшие практики, преимущества и советы для разработчиков
Освоение архитектуры микросервисов с Laravel: Лучшие практики, преимущества и советы для разработчиков
В последние годы архитектура микросервисов приобрела популярность как способ построения масштабируемых и гибких приложений. Laravel , популярный PHP...
Как построить CRUD-приложение в Laravel
Как построить CRUD-приложение в Laravel
Laravel - это популярный PHP-фреймворк, который позволяет быстро и легко создавать веб-приложения. Одной из наиболее распространенных задач в...
Освоение PHP и управление базами данных: Создание собственной СУБД - часть II
Освоение PHP и управление базами данных: Создание собственной СУБД - часть II
В предыдущем посте мы создали функциональность вставки и чтения для нашей динамической СУБД. В этом посте мы собираемся реализовать функции обновления...
Документирование API с помощью Swagger на Springboot
Документирование API с помощью Swagger на Springboot
В предыдущей статье мы уже узнали, как создать Rest API с помощью Springboot и MySql .
Роли и разрешения пользователей без пакета Laravel 9
Роли и разрешения пользователей без пакета Laravel 9
Этот пост изначально был опубликован на techsolutionstuff.com .
Как установить LAMP Stack - Security 5/5 на виртуальную машину Azure Linux VM
Как установить LAMP Stack - Security 5/5 на виртуальную машину Azure Linux VM
В предыдущей статье мы завершили установку базы данных, для тех, кто не знает.
4
1
66
3
Перейти к ответу Данный вопрос помечен как решенный

Ответы 3

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

Примечание. Я использовал современный синтаксис INNER 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
Ответ принят как подходящий

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

Демо

хорошее решение! Спасибо! У меня все еще есть проблема с моим настоящим запросом. Не могли бы вы взглянуть на внесенные мной изменения?

Sasha Grievus 18.12.2018 15:40

Я не могу ответить на ваш обновленный вопрос, потому что вы изменили структуру таблицы. Но похоже, что вы смешиваете неявный и явный синтаксис соединения, что не очень хорошо. Вы можете задать новый вопрос, а затем сослаться на этот.

Tim Biegeleisen 18.12.2018 15:45

Да, я проверил и удалил микс и сделал два внутренних соединения, это работает! Спасибо! Я удалю правку, потому что она может вводить в заблуждение проходящих мимо людей

Sasha Grievus 18.12.2018 15:47

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

 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

Другие вопросы по теме