今天写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子句中去。