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子句中去。
相关新闻>>
- 发表评论
- 
				
- 最新评论 进入详细评论页>>







