Oracle Group by语句出错

来源:网络 责任编辑:栏目编辑 发表时间:2013-07-01 13:18 点击:

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

    相关新闻>>

      发表评论
      请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
      用户名: 验证码:点击我更换图片
      最新评论 更多>>

      推荐热点

      • Table函数使用简介
      • Oracle数据库Constraint约束的常用操作及异常处理
      • Bulk Collect性能分析(zz)
      • export/import的使用
      • OCP043第十五讲 Database Security
      • ORACLE10gr2数据导入MySQL方案
      • oracle 让sys用户可以使用isqlplus
      • 在oracle数据库下使用iSQL*Plus DBA访问数据库
      • Oracle行列转换小结
      网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
      Copyright © 2008-2015 计算机技术学习交流网. 版权所有

      豫ICP备11007008号-1