私table1
は3つの列を持つテーブルを持っていますcolumn1, column2 and column3
。
column1
とはcolumn2
、FOREIGN KEY
他に 2 つのテーブルがあります。ただし、データcolumn3
は 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
第二の方法 -
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 つのクエリのどちらが安価ですか?