Oracle Group by语句出错
今天写SQL语句的时候
select sum(a.plate),sum(a.qty),sum(a.qly),a.materialtypeid,b.name,b.spec, from fw_eqpres_materialinventory a,fw_eng_material b where a.materialtypeid=b.sysid
and b.name like '%XX%'
group by a.materialtypeid
的时候提示 not a single group by function
但是写
select sum(a.plate),sum(a.qty),sum(a.qly),a.materialtypeid,b.name,b.spec from fw_eqpres_materialinventory a,fw_eng_material b where a.materialtypeid=b.sysid
and b.name like :name
a.materialtypeid,b.name,b.spec
又没有错,因此找了相关资料解释如下:
select state_cd,avg(sales) from customer group by state_cd;
大多数人一开始就明白groupby语句的意思,但使用时却常有麻烦。必须确保group by在每一个语句中引用正确的表列数目。提示当使用group by时,未在group by部分用到的表列在select部分出现时必须使用分组函数。
再考虑一下忽略使用分组函数可能引起的问题。如果执行了语句:
select last_name,state_cd,sum(sales) from customer
group by last_name;
将返回以下错误:
ERRORatline1:
ORA-00979:notaGROUPBYexpression
这是由于在state_cd表列中没有使用group by子句,因此必须加上分组函数。换句话说,必须使用max()、min()、sum()、count()或avg()函数。如果对于指定的表列找不到想使用的合适的分组函数,那么就将该表列移到group by子句中去。
相关新闻>>
- 发表评论
-
- 最新评论 更多>>