仅检索 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