Соединение двух таблиц без возврата нежелательной строки - PullRequest
2 голосов
/ 31 октября 2008

Моя структура таблицы выглядит следующим образом:

      tbl.users                       tbl.issues
+--------+-----------+   +---------+------------+-----------+
| userid | real_name |   | issueid | assignedid | creatorid |
+--------+-----------+   +---------+------------+-----------+
|   1    |   test_1  |   |    1    |     1      |     1     |
|   2    |   test_2  |   |    2    |     1      |     2     |
+--------+-----------+   +---------+------------+-----------+

В основном я хочу написать запрос, который закончится таблицей результатов, которая выглядит следующим образом:

                           (results table)
+---------+------------+---------------+-----------+--------------+
| issueid | assignedid | assigned_name | creatorid | creator_name |
+---------+------------+---------------+-----------+--------------+
|    1    |     1      |    test_1     |    1      |    test_1    |
|    2    |     1      |    test_1     |    2      |    test_2    |
+---------+------------+---------------+-----------+--------------+

Мой SQL выглядит следующим образом:

SELECT 
  `issues`.`issueid`,
  `issues`.`creatorid`,
  `issues`.`assignedid`,
  `users`.`real_name`
FROM `issues`
JOIN `users` 
  ON ( `users`.`userid` = `issues`.`creatorid` )
  OR (`users`.`userid` = `issues`.`assignedid`)
ORDER BY `issueid` ASC
LIMIT 0 , 30 

Это возвращает что-то вроде этого:

                (results table)
+---------+------------+-----------+-----------+
| issueid | assignedid | creatorid | real_name |
+---------+------------+-----------+-----------+
|    1    |     1      |     1     |   test_1  |
|    2    |     1      |     2     |   test_1  |
|    2    |     1      |     2     |   test_2  |
+---------+------------+-----------+-----------+

Может кто-нибудь помочь мне добраться до желаемой таблицы результатов?

Ответы [ 6 ]

7 голосов
/ 31 октября 2008
SELECT 
  IssueID, 
  AssignedID, 
  CreatorID, 
  AssignedUser.real_name AS AssignedName, 
  CreatorUser.real_name AS CreatorName
FROM Issues
  LEFT JOIN Users AS AssignedUser
         ON Issues.AssignedID = AssignedUser.UserID
  LEFT JOIN Users AS CreatorUser
         ON Issues.CreatorID = CreatorUser.UserID
ORDER BY `issueid` ASC
LIMIT 0, 30
3 голосов
/ 31 октября 2008

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

Визуальное объяснение соединений SQL

1 голос
/ 31 октября 2008

Используйте это:

SELECT 
`issues`.`issueid`,
`issues`.`creatorid`,
`creator`.`real_name`,
`issues`.`assignedid`,
`assigned`.`real_name`
FROM `issues` i
INNER JOIN `users` creator ON ( `creator`.`userid` = `issues`.`creatorid` )
INNER JOIN `users` assigned ON (`assigned`.`userid` = `issues`.`assignedid`)
ORDER BY `issueid` ASC
LIMIT 0 , 30
0 голосов
/ 31 октября 2008

SELECT
i.issueid
i.assignedid
a.real_name
i.creatorid,
c.real_name
ОТ
выдает я
Пользователи INNER JOIN c
ON c.userid = i.creatorid
INNER JOIN пользователи a
ON a.userid = i.assignedid
ЗАКАЗАТЬ НА
i.issueid ASC

0 голосов
/ 31 октября 2008

Это работает?

ВЫБРАТЬ i.issueid, i.assignedid, u1.real_name как назначенное_имя, i.creatorid, u2.real_name как создатель_имя ОТ пользователей u1 ВНУТРЕННЕЕ СОЕДИНЕНИЕ выдает мне ВКЛ u1.userid = i.assignedid ВНУТРЕННИЕ ПРИСОЕДИНЯЙТЕСЬ к пользователям u2 ON u2.userid = i.creatorid ЗАКАЗАТЬ по i.issueid

0 голосов
/ 31 октября 2008
SELECT DISTINCT (i.issueid, i.creatorid, i.assignedid, u.real_name)
FROM issues i, users u
WHERE u.userid = i.creatorid OR u.userid = assignedid
ORDER BY i.issueid ASC
LIMIT 0 , 30

Не уверен, нужны ли скобки или нет.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...