首页 > 数据库 > mysql教程 > 如何仅检索 LEFT JOIN 中的第一行?

如何仅检索 LEFT JOIN 中的第一行?

Susan Sarandon
发布: 2024-11-07 18:01:02
原创
608 人浏览过

How to Retrieve Only the First Row in a LEFT JOIN?

仅检索 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
登录后复制

要检索feed 文章并仅将第一个艺术家与每个 feed 关联,可以尝试以下语法:

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 将仅检索与每个提要关联的第一个艺术家。

以上是如何仅检索 LEFT JOIN 中的第一行?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板