首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在排序依据后选择一条记录

在排序依据后选择一条记录
EN

Stack Overflow用户
提问于 2012-12-29 03:04:28
回答 3查看 283关注 0票数 0

我有一堆CD里面有一堆艺术品。我想在网页上显示每张CD的缩略图,为此,我需要从该CD的许多现有艺术作品中选择一个图像...

该查询将选择所有图稿,I group by position,并希望选取第一个图稿。我不知道如何在排序后只为每个记录挑选第一张图像…

查询如下:

代码语言:javascript
复制
SELECT release_artwork.release_id, release_artwork.position, artwork.small_filename, artwork.small_width, artwork.small_height
FROM release_artwork
JOIN artwork ON artwork.artwork_id = release_artwork.artwork_id
ORDER BY release_artwork.position

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2012-12-29 03:17:46

我手边没有MySQL实例,但这应该可以工作-只需定义一个内联表来保存最小值,然后连接到该表。

代码语言:javascript
复制
SELECT release_artwork.release_id, release_artwork.position, artwork.small_filename, artwork.small_width, artwork.small_height
FROM
  release_artwork
  inner JOIN artwork ON artwork.artwork_id = release_artwork.artwork_id
  inner join
  (
  SELECT
    ra.release_id as release_id
   ,min(ra.position) as rap
  FROM
    release_artwork ra
  group by
    ra.release_id
  ) mins
  on mins.release_id = release_artwork.release_id
    and mins.rap = release_artwork.position
ORDER BY
  release_artwork.release_id
票数 4
EN

Stack Overflow用户

发布于 2012-12-29 03:06:31

在这种情况下,您可以使用LIMIT 1将检索的结果限制为只检索第一个结果。

票数 2
EN

Stack Overflow用户

发布于 2012-12-29 03:08:12

代码语言:javascript
复制
SELECT release_artwork.release_id, release_artwork.position, artwork.small_filename, artwork.small_width, artwork.small_height
FROM release_artwork
JOIN artwork ON artwork.artwork_id = release_artwork.artwork_id
ORDER BY release_artwork.position LIMIT 1

在末尾添加LIMIT 1会将其限制为单个结果。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/14074423

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档