LEFT OUTER JOIN vs SUBSELECT в MySQL

У меня есть таблица, скажем table1, которая имеет 3 столбца column1, column2 и column3.

столбец 1 и столбец 2 являются FOREIGN KEY с двумя другими таблицами. Однако данные в столбце 3 взяты из n таблиц.

Например, Давайте рассмотрим Facebook. Чтобы отобразить действия, он может поддерживать таблицу, которая может иметь user1 photoliked photo1или user1 statusliked status1. Таким образом, в этом случае column3не может быть FOREIGN KEYдля конкретной таблицы.

Теперь есть 2 способа получения реальных данных -

1-й способ -

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-й способ -

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

Вопрос

Какой из 2-х способов лучше получить данные? и какой из 2-х запросов дешевле?

6
задан Zane Bien 20 June 2012 в 05:05
поделиться