У меня есть таблица, скажем 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-х запросов дешевле?