请教 sql 查询怎样先排序再 group by ?

2017-10-02 23:04:51 +08:00
 gdtv

要求: 查询出每一组 a 里最大的 b 值

表结构:

CREATE TABLE `test` (
  `a` int(11) NOT NULL,
  `b` int(11) NOT NULL
)

示例数据:

a    b
1    1000
1    2000
2    1000
2    2000

期望结果:

a    b
1    2000
2    2000

SQL 语句:

SELECT T.* FROM (select * from `test` order by b desc) T group by T.a

实际运行结果:

a    b
1    1000
2    1000

请问 SQL 该怎么写才正确?

7059 次点击
所在节点    MySQL
5 条回复
woshixiaomao
2017-10-02 23:11:06 +08:00
SELECT `a`, MAX(`b`) AS `b` FROM `test GROUP BY `a` 这样?
zjp
2017-10-02 23:45:53 +08:00
你需要的的是最大值,和排序无关。
一楼少个`😂
msg7086
2017-10-03 08:39:59 +08:00
GROUP BY 聚合函数在聚合行的时候顺序是不确定的,多次运行的结果都有可能会不同。
必须要用子查询或者程序逻辑来获取特定的行的结果。
cye3s
2017-10-03 14:21:49 +08:00
Max(b) over (partition by a),不试过分析函数?没有?
woshixiaomao
2017-10-03 18:21:44 +08:00
@zip 被发现了。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/395218

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX