首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >MySQL:始终选择第一个行

MySQL:始终选择第一个行
EN

Stack Overflow用户
提问于 2018-07-22 23:49:28
回答 2查看 71关注 0票数 0

我有一个表,其中多个列按一个属性(Attr1)排序,并且我希望(使用mySQL)始终选择新值的第一行:

我该怎么做呢?

非常感谢!

编辑:很抱歉,我的问题陈述得不够清楚。考虑这个新的示例表:

假设我有一个博客,其中有几篇文章可以被用户评论。在第一页(起始页),我想列出每个帖子的最新评论。因此,我得到所有评论,并首先按post_id排序,然后按时间戳排序(按post_id排序,按时间戳排序)。然而,正如我所说的,我只对最新的评论感兴趣(对于每个帖子),而不是所有的评论。因此,期望的输出是橙色的行,因为它是post_id 1、post_id 2和post_id 3的最新注释。

如果我用PHP解决这个问题,我会简单地获取整个表并遍历所有行,只有在post_id与前一个不匹配的情况下才回显注释。

希望这能让事情变得更清楚。使用MySQL可以做到这一点吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-07-22 23:56:40

如果您希望始终使用最低的ID作为第一个结果,并且希望所有这些行都是橙色的,那么这对您来说是可行的!

代码语言:javascript
复制
SELECT * FROM your_table GROUPY BY Attr1 ORDER BY id

但正如另一个答案所说,他不认为你想要所有这些行,而是只想要一行,然后使用他的答案。

数据库表:

结果:

票数 0
EN

Stack Overflow用户

发布于 2018-07-22 23:53:14

使用Limitorder by子句

代码语言:javascript
复制
select * from your_table ORDER BY Attr1 desc Limit 1
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51466771

复制
相关文章

相似问题

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