首页  >  文章  >  数据库  >  如何从每个左表条目的 LEFT JOIN 中仅检索第一行?

如何从每个左表条目的 LEFT JOIN 中仅检索第一行?

Mary-Kate Olsen
Mary-Kate Olsen原创
2024-11-05 14:27:02243浏览

How to retrieve only the first row from a LEFT JOIN for each left table entry?

获取 LEFT JOIN 的第一行

在 SQL 中,执行 LEFT JOIN 通常会生成左表的多行,其中一个对于右表中的每个对应行。但是,在某些情况下,可能需要仅检索左表的第一行。

简化的数据库结构

考虑以下简化的数据库结构:

  • 动态

    id |  title | content
    ----------------------
    1  | Feed 1 | ...
  • 艺术家

    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 的第一位艺术家,通常使用 LEFT JOIN。以下查询表示初步尝试:

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'

此查询旨在仅检索每个 feed ID 的 feeds_artists 表的第一行。但是,它无法有效地工作。

解决方案

要成功提取每个提要的第一位艺术家,可以使用以下查询:

SELECT *
  FROM feeds f
  LEFT JOIN artists a ON a.artist_id = (
    SELECT artist_id
    FROM feeds_artists fa 
    WHERE fa.feed_id = f.id
    LIMIT 1
  )

在此修订后的查询中,子查询确保艺术家值代表每个 Feed ID 的 feeds_artists 表中的第一行。 LIMIT 1 子句在仅选择第一行方面起着至关重要的作用。

递增 ID 的替代解决方案

如果可以假设艺术家 ID 随着时间的推移而递增,提出了另一种解决方案:

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.feed_id
  )

这里,MIN(artist_id) 子查询返回具有最低值的艺术家 ID,假设这对应于最早的艺术家。

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

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn