桐&露 2022-06-24 08:54 采纳率: 40%
浏览 45
已结题

聚合函数参数为什么不能使用子查询的返回值

关于聚合函数内需要的数据类型的问题

ORACLE数据库的子查询部分的试题

问题:查询各部门平均工资中最高的部门
字段:DEPTNO部门编号 SAL薪资 EMP表名

原题正解是将子查询作为数据源
SELECT DEPTNO FROM EMP
GROUP BY DEPTNO
HAVING AVG(SAL) = (SELECT MAX(A) FROM (SELECT DEPTNO,AVG(SAL) A FROM EMP GROUP BY DEPTNO))

问题解:
将求最高平均薪资的部分按照如下方式来求
SELECT MAX((SELECT AVG(SAL) FROM EMP GROUP BY DEPTNO)) --子查询是一行三列的数据
FROM EMP;
--ERROR:单行子查询结果返回多行

个人想法:
做这个方式的原因是想练习子查询,本身通过MAX(AVG(SAL)) +GROUP BY 也可以求得最高平均薪资(聚合函数的嵌套),但是想尝试一下用子查询,发现居然会报错。
个人理解上认为SELECT的查询结果是一个一列多行的结果,AVG()+GROUP BY好像也是。
为什么就会出现如上错误(单行子查询结果返回多行)

  • 写回答

1条回答 默认 最新

  • 微笑精灵 2022-06-24 17:51
    关注

    表不能作为聚合查询的元素

    img


    聚合函数接受的参数是表的字段,而不是某个集合。
    就像我图片中那么写是不行的。
    你说的问题就是这么个情况

    img

    你可以这么写

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 7月6日
  • 已采纳回答 6月28日
  • 创建了问题 6月24日

悬赏问题

  • ¥15 echarts动画效果失效的问题。官网下载的例子。
  • ¥60 许可证msc licensing软件报错显示已有相同版本软件,但是下一步显示无法读取日志目录。
  • ¥15 Attention is all you need 的代码运行
  • ¥15 一个服务器已经有一个系统了如果用usb再装一个系统,原来的系统会被覆盖掉吗
  • ¥15 使用esm_msa1_t12_100M_UR50S蛋白质语言模型进行零样本预测时,终端显示出了sequence handled的进度条,但是并不出结果就自动终止回到命令提示行了是怎么回事:
  • ¥15 前置放大电路与功率放大电路相连放大倍数出现问题
  • ¥30 关于<main>标签页面跳转的问题
  • ¥80 部署运行web自动化项目
  • ¥15 腾讯云如何建立同一个项目中物模型之间的联系
  • ¥30 VMware 云桌面水印如何添加