僅檢索LEFT JOIN 中的第一行
在SQL 中,執行LEFT JOIN 操作可能會導致右表中出現多行與左表中的一行相符。在某些情況下,希望為左表中的每一行僅檢索右表中的第一行。
考慮以下簡化的資料結構:
**Feeds** id | title | content ---------------------- 1 | Feed 1 | ... **Artists** artist_id | artist_name ----------------------- 1 | Artist 1 2 | Artist 2 **feeds_artists** rel_id | artist_id | feed_id ---------------------------- 1 | 1 | 1 2 | 2 | 1
要檢索提要文章並僅將第一位藝術家與每個提要相關聯,可以嘗試使用以下語法:
SELECT * FROM feeds LEFT JOIN feeds_artists ON wp_feeds.id = ( SELECT feeds_artists.feed_id FROM feeds_artists WHERE feeds_artists.feed_id = feeds.id LIMIT 1 ) WHERE feeds.id = '13815'
但是,這種方法可能不會產生預期的結果。要實現該目標,請考慮以下替代方案:
SELECT * FROM feeds f LEFT JOIN artists a ON a.artist_id = ( SELECT MIN(fa.artist_id) a_id FROM feeds_artists fa WHERE fa.feed_id = f.id )
此修改使用 MIN() 函數來確定具有最低 ID 的藝術家,假設藝術家 ID 隨著時間的推移而增加。因此,LEFT JOIN 將僅檢索與每個提要關聯的第一個藝術家。
免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。
Copyright© 2022 湘ICP备2022001581号-3