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