MySQL Как мне правильно запустить этот подзапрос? - PullRequest
0 голосов
/ 01 марта 2012

У меня есть следующие таблицы базы данных:

People
+--------+------------+------------+-----------+
|  f_ID  |  F_NAME    |    STUFF   | F_VALUE   | 
+--------+------------+------------+-----------+
|    1   |   Zoe      |    blah    |     101   |
|    2   |   Jimy     |    derka   |     202   |
|    3   |   Kate     |    shazam  |     20    |
|    4   |   Sue      |    pow     |      2    |
+--------+------------+------------+-----------+

RESULTS
+------- ---+------------+
| F_ID      |   RESULTS  | 
+-----------+------------+
| 1         |     Good   |
| 4         |      OK    |
+-----------+------------+

Как создать запрос для отображения всех записей в таблице пользователей следующим образом:

+------------+------------+
|   NAME     |    GRADE   | 
+------------+------------+
|   Zoe      |     Good   |
|   Jimy     |     N/A    |
|   Kate     |     N/A    |
|   Sue      |     OK     |
+------------+------------+

Я пробовал этот запрос, но онне работает правильно:

SELECT 
NAME
GRADE
(
SELECT 
p.F_NAME AS NAME,
r.RESULTS

FROM People p
JOIN RESULTS r ON r.F_ID=p.F_ID

UNION

SELECT 
p.F_NAME AS NAME,
"N/A"

FROM People p
JOIN RESULTS r ON r.F_ID=p.F_ID
)a

Ответы [ 3 ]

2 голосов
/ 01 марта 2012

Вы должны использовать левое соединение. Вы получите NULL для GRADE, где записи не существуют. При представлении данных просто поставьте N / A вместо NULL.

select People.F_NAME as NAME, RESULTS.RESULTS AS GRADE
from People left join RESULTS ON People.f_ID = RESULTS.f_ID

или, если вы хотите N / A вместо NULL, используйте IF

select People.F_NAME as NAME, IF(RESULTS.RESULTS is NULL, 'N/A', RESULTS.RESULTS) AS GRADE
from People left join RESULTS ON People.f_ID = RESULTS.f_ID

или используя COALESCE (спасибо @bfavaretto)

select People.F_NAME as NAME, COALESCE(RESULTS.RESULTS, 'N/A') AS GRADE
from People left join RESULTS ON People.f_ID = RESULTS.f_ID
1 голос
/ 01 марта 2012

без использования UNION, вы можете достичь этого с помощью LEFT JOIN

SELECT  a.F_Name, 
        COALESCE(b.Results, 'N/A') Grade
FROM    People a LEFT JOIN Results b ON
            a.f_IF = b.F_ID
1 голос
/ 01 марта 2012

Может быть достигнуто с помощью объединения

SELECT people.f_name, IF(results.grade <> 0, results.grade, 'N/A') from people
JOIN results USING(f_id)
...