
要求: 查询出每一组 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 该怎么写才正确?
1 woshixiaomao 2017-10-02 23:11:06 +08:00 SELECT `a`, MAX(`b`) AS `b` FROM `test GROUP BY `a` 这样? |
2 zjp 2017-10-02 23:45:53 +08:00 via Android 你需要的的是最大值,和排序无关。 一楼少个` |
3 msg7086 2017-10-03 08:39:59 +08:00 GROUP BY 聚合函数在聚合行的时候顺序是不确定的,多次运行的结果都有可能会不同。 必须要用子查询或者程序逻辑来获取特定的行的结果。 |
4 cye3s 2017-10-03 14:21:49 +08:00 via iPad Max(b) over (partition by a),不试过分析函数?没有? |
5 woshixiaomao 2017-10-03 18:21:44 +08:00 @zip 被发现了。 |