Mam tabelę powiedzieć table1
, który ma 3 kolumny column1, column2 and column3
.LEFT OUTER JOIN vs SUBSELECT w MySQL
The column1
i column2
są FOREIGN KEY
z 2 innymi tabelami. Jednak dane w column3
pochodzą z liczby n tabel.
Dla np. Rozważmy Facebooka. Aby wyświetlić działania, może on utrzymywać tabelę, która może mieć wartość user1 photoliked photo1
lub. W takim przypadku column3
nie może być FOREIGN KEY
z określoną tabelą.
Teraz są 2 sposoby na uzyskanie prawdziwego danych -
1-ty sposób -
SELECT user_id,
verb_id,
CASE WHEN verb_id = photoliked THEN
(SELECT photo_name FROM photos WHERE photo_id = column3) -- getting the desired data from the third column
WHEN verb_id = statusliked THEN
(SELECT status FROM statustable WHERE status_id = column3)
ELSE '' END AS performedon
FROM table1
JOIN table2 ON user_id = user_id -- joining the first column
JOIN table3 ON verb_id = verb_id -- joining the second column
2 sposób -
SELECT user_id,
verb_id,
CASE WHEN verb_id = photoliked THEN
p.photo_name
WHEN verb_id = statusliked THEN
s.status
ELSE '' END AS performedon
FROM table1
JOIN table2 ON user_id = user_id -- joining the first column
JOIN table3 ON verb_id = verb_id -- joining the second column
LEFT JOIN photos p ON p.photo_id = column3 -- joining the column3 with specific table
LEFT JOIN statustable s ON s.status_id = column3
Pytanie
Które z 2 sposoby lepiej jest odzyskać dane? i które z 2 zapytań jest tańsze?
Możliwy duplikat http://stackoverflow.com/a/10684539/1239506 –
Nie, to nie jest duplikat. W pytaniu tym występuje "IN" w klauzuli "WHERE", a "SUBSELECT" nie zależy od żadnej kolumny głównej zapytania. – JHS
Druga kwerenda jest lepsza ... –