首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >获取具有最大值的行(列)

获取具有最大值的行(列)
EN

Stack Overflow用户
提问于 2012-07-07 00:12:56
回答 5查看 2.6K关注 0票数 3

每当我使用max函数时,不知何故我就失去了与其他值的所有连接,因此稍后打印的行将不再与我运行max的列相关联。

所以我的表格是:

代码语言:javascript
运行
复制
user col1 col2 col3
1    1    2    3
1    3    4    5
2    2    3    1
3    1    1    3
3    2    4    6
4    5    1    5

所以如果我运行

代码语言:javascript
运行
复制
select user, col1, col2, max(col3) as col3
from table
group by user
order by user;

我会得到

代码语言:javascript
运行
复制
user col1 col2 col3
1    1    2    5
2    2    3    1
3    1    1    6
4    5    1    5

所以col3的最大值是正确的,但是它没有得到该值的正确行。

我想要的是获取列的最大值,并为每个用户返回该行。如果有多个最大值,它应该返回所有用户,即使它具有相同的用户id。

EN

Stack Overflow用户

发布于 2012-07-07 00:17:31

您需要从查询中删除col1和col2,因为它们使行是惟一的。试一试

代码语言:javascript
运行
复制
SELECT user, max(col3) AS col3 FROM table GROUP BY user ORDER BY user;
票数 1
EN
查看全部 5 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/11365937

复制
相关文章

相似问题

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