首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >使用MAX时,将从SQL查询中排除行

使用MAX时,将从SQL查询中排除行
EN

Stack Overflow用户
提问于 2020-01-30 03:10:09
回答 3查看 38关注 0票数 0

我有A桌

一个

中-总计

1-3

5-3

2-2

4-1

当运行此命令时

代码语言:javascript
运行
复制
SELECT * FROM A HAVING A.totals=3;

不出所料地给予

中-总计

1-3

5-3

但是当我运行SELECT * FROM A HAVING (A.totals=(max(A.totals));

只给出中-总数

1-3

而不是第二排。我需要能够使用最大值,因为在总数列中的数字将发生变化。我该怎么做呢?

EN

回答 3

Stack Overflow用户

发布于 2020-01-30 03:21:52

使用以下查询:

代码语言:javascript
运行
复制
SELECT * FROM A HAVING  A.totals=(SELECT max(B.totals) FROM A B) ;

Fiddle

票数 0
EN

Stack Overflow用户

发布于 2020-01-30 03:22:47

我们可以这样做:

代码语言:javascript
运行
复制
SELECT d.mid
     , d.totals
  FROM ( SELECT MAX(s.totals) AS max_totals FROM A s ) t
  JOIN A d
    ON d.totals = t.max_totals
 ORDER
    BY d.mid 
     , d.totals

我们可以返回等价的结果,如下所示:

代码语言:javascript
运行
复制
SELECT d.mid
     , d.totals
  FROM A d
 WHERE d.totals IN ( SELECT MAX(s.totals) FROM A s )
 ORDER
    BY d.mid 
     , d.totals

问题中的查询也可以有效地返回零行。

该行为是由于MySQL (非标准)扩展造成的。其他数据库会拒绝该查询,返回一个错误。我们可以通过在sql_mode中包含ONLY_FULL_GROUP_BY来让MySQL表现出类似的(更标准的)行为,然后MySQL会抛出一个错误1463。

参考:https://dev.mysql.com/doc/refman/8.0/en/group-by-handling.html

票数 0
EN

Stack Overflow用户

发布于 2020-01-30 03:26:51

HAVINGGROUP BY聚合一起使用

请改用WHERE

代码语言:javascript
运行
复制
SELECT * FROM A WHERE A.totals = (SELECT MAX(A.totals) FROM A)
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59973986

复制
相关文章

相似问题

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