今天在分组统计的时候pgsql报错 must appear in the GROUP BY clause or be used in an aggregate function,在mysql里面是可以的,但是pgsql报错,我去stackoverflow查询了一下,发现有人遇到过和我一样的问题,这是pgsql一个常见的聚合问题,在SQL3标准以前,选择显示的字段必须出现在在 GROUP BY 中。下面我把问题描述一下:

有一张表叫 makerar,表中记录如下:
cname | wmname | avg
--------|--------|-----------------------
canada | zoro | 2.00
spain | luffy | 1.00
spain | usopp | 5.00

我想要查询每个 cname 的最大 avg,按照mysql的写法是

SELECT cname, wmname, MAX(avg) FROM makerar GROUP BY cname;

在pgsql中报错

ERROR:  column "makerar.wmname" must appear in the GROUP BY clause or be used in an aggregate function
LINE 1: SELECT cname, wmname, MAX(avg)  FROM makerar GROUP BY cname;

意思是 wmname 字段必须在 GROUP BY 中出现或者被用于聚合函数

于是我按照错误提示,把 wmname 字段加在 GROUP BY 后面,即

SELECT cname, wmname, MAX(avg) FROM makerar GROUP BY cname, wmname;

得到的结果是

cname wmname avg
canada zoro 2.00
spain luffy 1.00
spain usopp 5.00

而我期望得到的结果是

cname wmname avg
canada zoro 2.00
spain usopp 5.00

解决方案有两种,但是我只看懂了一种,于是把这一种记录一下

大体思路是在子查询中完成聚合,然后关联包含你想显示字段的表(这里是makerar自身)获取字段(这里是wmname),所以sql就变成了下面这个样子

SELECT   t.cname,m.wmname,t.max
FROM (SELECT cname,MAX(avg) AS max FROM makerarGROUP BY cname) t
LEFT JOIN makerar m ON t.cname = m.cname AND t.max = m.avg;

参考链接

https://stackoverflow.com/questions/19601948/must-appear-in-the-group-by-clause-or-be-used-in-an-aggregate-function#

转载于:https://www.cnblogs.com/zxhyJack/p/9934259.html

must appear in the GROUP BY clause or be used in an aggregate function相关推荐

  1. InfluxDB:cannot use field in group by clause

    最近在使用InfluxDB时,发现一个很奇怪的问题,一个本来正常的功能,做了一次改动后,就不能正常显示了. 一.查询语句 SELECT MEMORY FROM "ACM_PROCESS_MO ...

  2. mySql中Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggre的问题

    报错信息 Expression #2 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'a.id' ...

  3. lly dependent on columns in GROUP BY clause; this is incompatible with sql_m

    报错 ERROR 1055 (42000): Expression #2 of SELECT list is not in GROUP BY clause and contains nonaggreg ...

  4. 【阿里云 Linux 服务器】mysql 遇到以下问题Expression #1 of SELECT list is not in GROUP BY clause and contains nonag

    报错信息如下: Caused by: java.sql.SQLSyntaxErrorException: Expression #1 of SELECT list is not in GROUP BY ...

  5. Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column

    场景 安装了mysql5.7,用group by 查询时抛出如下异常: Expression #1 of SELECT list is not in GROUP BY clause and conta ...

  6. [Err] 1055 - Expression #1 of ORDER BY clause is not in GROUP BY clause and contains nonaggregated

    mysql客户端查询报这个错误,如下所示: [Err] 1055 - Expression #1 of ORDER BY clause is not in GROUP BY clause and co ...

  7. mysql Expression #1 of ORDER BY clause is not in GROUP BY clause and contains nona

    1. 操作mysql的时候提示如下错误 [Err] 1055 - Expression #1 of ORDER BY clause is not in GROUP BY clause and cont ...

  8. which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mod

    which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mod ...

  9. 1055 - Expression #1 of SELECT list is not in GROUP BY clause and contains解决

    1055 - Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'btc ...

最新文章

  1. android 观察者,Android开发实现简单的观察者与被观察者示例
  2. NLP哪个细分方向最具社会价值?
  3. C# 按钮美化技巧
  4. Js Tween 实现
  5. Web Hacking 101 中文版 九、应用逻辑漏洞(一)
  6. java limit_Java 8 Stream:limit()和skip()之间的区别
  7. 1、深入理解 Laravel Eloquent(一)——基本概念及用法
  8. 用C#实现软件自动更新思路
  9. 拖放drag drop(PyQt或Qt for python)
  10. 网上流传的飞扬学院Java_收获| 云和JAVA、UI双班毕业,飞扬青春再出发!
  11. 走格子(bfs+dji)
  12. Windows​服务器添加单IP不同段IP和整段IP
  13. CSS实现文字凹凸效果
  14. PaddlePaddle笔记4-看图写诗
  15. 【滤波跟踪】基于随机有限集的多目标跟踪算法附matlab代码
  16. 计算机开机显示器不亮,电脑开机显示器不亮该如何解决
  17. Linux常用命令——rsync命令
  18. Linux系统安全应用
  19. 精准医学中的深度学习和影像组学
  20. UCOSIII-任务管理

热门文章

  1. C# 获取当前系统时间 与某一时间相减
  2. 滤波器辅助设计软件Filter Wiz Pro的使用
  3. docker kill 强制停止容器
  4. 详谈单精度浮点数在内存中的存储及其误差问题
  5. python 子图共用x轴_创建两个子图后如何共享它们的x轴?
  6. HDU - 4918
  7. COCOS2dX - 集成PayPa
  8. 三星A7计算机,三星A72手机参数怎么样?三星a72参数一览
  9. STM32学习总结——SMT32基本知识
  10. 被三只松鼠与良品铺子甩远后,来伊份还有自救希望吗?