私はテーブルがtable1
の3つのカラムcolumn1, column2 and column3
を持っていると言います。LEFT OUTER JOINとSUBSELECTのMySQL
column1
およびcolumn2
は、FOREIGN KEY
で、2つの他のテーブルがあります。しかし、column3
のデータはn個のテーブルからのものです。
私たちはFacebookを考えてみましょう。アクティビティを表示するには、user1 photoliked photo1
またはuser1 statusliked status1
のテーブルを保持することがあります。この場合、column3
は特定のテーブルを持つFOREIGN KEY
になることはできません。
第一の方法 - -
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つの方法がありますデータを取得する方が良いですか? と2つのクエリのどちらが安価ですか?
可能な重複http://stackoverflow.com/a/10684539/1239506 –
ありません、それは複製されません。その質問では、 'WHERE'節に' IN'があり、 'SUBSELECT'はメイン問い合わせのどの列にも依存しません。 – JHS
2番目のクエリはより良いです... –