我有A桌
一个
中-总计
1-3
5-3
2-2
4-1
当运行此命令时
SELECT * FROM A HAVING A.totals=3;
不出所料地给予
中-总计
1-3
5-3
但是当我运行SELECT * FROM A HAVING (A.totals=(max(A.totals));
时
只给出中-总数
1-3
而不是第二排。我需要能够使用最大值,因为在总数列中的数字将发生变化。我该怎么做呢?
发布于 2020-01-30 03:21:52
使用以下查询:
SELECT * FROM A HAVING A.totals=(SELECT max(B.totals) FROM A B) ;
Fiddle
发布于 2020-01-30 03:22:47
我们可以这样做:
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
我们可以返回等价的结果,如下所示:
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
发布于 2020-01-30 03:26:51
HAVING
与GROUP BY
聚合一起使用
请改用WHERE
SELECT * FROM A WHERE A.totals = (SELECT MAX(A.totals) FROM A)
https://stackoverflow.com/questions/59973986
复制相似问题