博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Hive SemanticException:Expression not in GROUP BY
阅读量:6260 次
发布时间:2019-06-22

本文共 656 字,大约阅读时间需要 2 分钟。

hot3.png

问题描述

在 hive 中执行以下 sql:

select av_seq, cp_seq  from dw.smbrandcp group by av_seq;

提示报错:

FAILED: SemanticException [Error 10025]: Line 1:15 Expression not in GROUP BY key 'cp_seq'

错误分析

很显然,错误信息已经告诉我们了这是一个语法错误。当使用 group by 子句时, select 语句只能包含 group by 子句中的字段。当然 select 语句中也可以有多个聚合函数 (例如 count)。

在本例中,smbrandcp 表大致如下:

av_seq cp_seq
944076 CC200940
944076 CC200743
944076 CC200777

在执行下面的查询时:

select av_seq, cp_seq  from dw.smbrandcp group by av_seq;

由于只是在 av_seq 字段上面做聚合,那么对于聚合操作 av_seq = 944076, cp_seq 应该取什么样的值呢?这样就会产生多种可能选项。Hive 对于这种字段在 select 语句中而不在 group by 子句中的 SQL 的处理方式就是将其当做一个无效 SQL, 因为 HQL 要的就是精确。

参考资料

转载于:https://my.oschina.net/jackieyeah/blog/679150

你可能感兴趣的文章
仿CSDN Blog返回页面顶部功能
查看>>
【HTML5游戏开发小技巧】RPG情形对话中,令文本逐琢夸出
查看>>
ORA-04031:
查看>>
早晚有一天,我们都会成为自己当初讨厌的人
查看>>
基于SMTP协议的CMD命令邮件发送
查看>>
九度笔记之 1209最小邮票数
查看>>
Java中swap解惑
查看>>
HDU 2068 RPG的错排
查看>>
操作数有自增操作时复合表达式的陷阱
查看>>
从WW中剥离一个三维场景框架
查看>>
ASP.NET网页动态添加、更新或删除数据行
查看>>
vbs获取当前主机IP
查看>>
IIS7中的站点、应用程序和虚拟目录详细介绍
查看>>
为何C语言(的函数调用)需要堆栈,而汇编语言却不需要堆栈
查看>>
对Map按key和value分别排序
查看>>
知名第三方编译版tete009 Firefox 24.0
查看>>
java反射生成ORM
查看>>
堆和栈的区别
查看>>
生成CSV文件后再将CSV文件导入到mysql
查看>>
Html.DropDownListFor练习(2)
查看>>