MySQL聚合函数的问题

MySQL初学者,牛客网刷题遇到了下面的题

img


自己用了两次窗口函数,先正序再倒序排列,套了三次子查询勉强做出来了,后来看到了答案,写法很简洁

img

但是看完答案有个疑问,round函数里面有好多聚合函数,像sum、min、max、count,却并没有用group by进行分组,即使是这样也能获得正确的结果。我试着把where后面的两个过滤条件删除一个,只保留 where tag='SQL',就会报错。两个过滤条件都写上的话就能正常运行,这是什么原因呢?

这里的 round 函数可能是一个内置的聚合函数,用于将一组数据聚合为一个标量值。此时,如果你只保留其中的一个过滤条件 where tag='SQL' ,那么查询结果中可能会包含多个不同的标签 tag,而 round 函数会尝试将这些数据聚合为一个标量值,因此会报错。

相反,如果你保留了两个过滤条件,比如 where tag='SQL' and id > 100,那么查询结果中只会包含满足这两个条件的数据,而这些数据都具有相同的标签 tag,因此 round 函数可以顺利地将它们聚合为一个标量值。

在这种情况下,你不需要使用 group by 进行分组,因为你的查询语句已经通过 where 条件进行了过滤,只返回了符合条件的数据。group by 通常用于在查询结果中分组并聚合数据,以获得更详细的信息。

总之,要根据具体情况来决定是否需要使用 group by 分组,以及如何使用聚合函数进行计算。

因为你的 select 显式的列出了 difficulty,如果diffculty 有不同的值,无法自动合并,当显式字段的值都相同时,使用聚合函数,相当于自动 group 所有显式字段

不知道你这个问题是否已经解决, 如果还没有解决的话:

如果你已经解决了该问题, 非常希望你能够分享一下解决方案, 写成博客, 将相关链接放在评论区, 以帮助更多的人 ^-^