要求: 查询出每一组 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 2
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 被发现了。
|