Ho un tavolo dire table1
che ha 3 colonne column1, column2 and column3
.LEFT OUTER JOIN vs SUBSELECT in MySQL
Il column1
e column2
sono uno FOREIGN KEY
con altri 2 tavoli. Tuttavia i dati in column3
provengono da n numero di tabelle.
Ad es. Prendiamo in considerazione Facebook. Per visualizzare le attività potrebbe mantenere una tabella che potrebbe avere user1 photoliked photo1
o user1 statusliked status1
. Quindi in questo caso column3
non può essere un FOREIGN KEY
con una tabella specifica.
Ora ci sono 2 modi di ottenere dati reali -
1 ° modo -
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 ° modo -
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
Domanda
Quale dei 2 modi è meglio recuperare i dati? e quale delle due query è meno costosa?
Eventuali duplicati http://stackoverflow.com/a/10684539/1239506 –
No, non è duplicato. In quella domanda c'è un 'IN' nella clausola' WHERE' e 'SUBSELECT' non dipende da nessuna colonna della query principale. – JHS
La seconda query è migliore ... –