在oracle的聚合函数(sum、avg等)中使用group by来分组你的结果
2014-08-09 11:14
148 查看
前面我们介绍了几个oralce中聚合函数(count、max、min、sum、avg等),但实际上在oracle中,单独使用这几个聚合函数的机会并不多,通常是和group by 关键字结合使用的。
Group by的含义是对结果进行分组。结合具体的例子来说好了,比如要计算工资的平均值,我们可以对每个部门进行分别求平均值,这样就能看出研发部门和销售部门待遇的差距了,呵呵!
要按部门求得平均值,就不得不使用group by 关键字了。
Select avg(sal) from emp;
这个是全公司的工资平均值。
Select deptno,avg(sal)
from emp
group by deptno
这个求的是按部门的工资平均值
这里有几个问题需要说明:
group by 后面接的是分组的标准,可以接多个值,比如可以对公司的部门员工在细分至工种,即可以求得某个部门不同工种的平均工资。
group by后接的列中可以是select 列表项中不存在的(虽然可以,但一般也不推荐这么做,因为这样的话,将会使得结果比较混乱,不知道这个结果对应的哪一项),但反过来就不行了,在select列表项中出现的列必须全部出现在group by后面(聚合函数除外)
还有一点是如果在select 列表项中除了包含聚合函数外,还包含了表的某些列,那么你将必须使用group by语句,否则语法通不过。
下面是一个按部门和不同工种给出的例子
select deptno,job,avg(sal)
from emp
group by deptno,job;
Group by的含义是对结果进行分组。结合具体的例子来说好了,比如要计算工资的平均值,我们可以对每个部门进行分别求平均值,这样就能看出研发部门和销售部门待遇的差距了,呵呵!
要按部门求得平均值,就不得不使用group by 关键字了。
Select avg(sal) from emp;
这个是全公司的工资平均值。
Select deptno,avg(sal)
from emp
group by deptno
这个求的是按部门的工资平均值
这里有几个问题需要说明:
group by 后面接的是分组的标准,可以接多个值,比如可以对公司的部门员工在细分至工种,即可以求得某个部门不同工种的平均工资。
group by后接的列中可以是select 列表项中不存在的(虽然可以,但一般也不推荐这么做,因为这样的话,将会使得结果比较混乱,不知道这个结果对应的哪一项),但反过来就不行了,在select列表项中出现的列必须全部出现在group by后面(聚合函数除外)
还有一点是如果在select 列表项中除了包含聚合函数外,还包含了表的某些列,那么你将必须使用group by语句,否则语法通不过。
下面是一个按部门和不同工种给出的例子
select deptno,job,avg(sal)
from emp
group by deptno,job;
相关文章推荐
- GROUP BY 聚合函数(max min sum avg count) 和HAVING的 使用
- 在oracle的聚合函数(sum、avg等)中使用NVL函数,强迫加入空值
- elasticsearch聚合操作——本质就是针对搜索后的结果使用桶bucket(允许嵌套)进行group by,统计下分组结果,包括min/max/avg
- 在oracle的聚合函数(sum、avg等)中使用NVL函数,强迫加入空值
- hibernate如何使用criteria查詢 oracle分组group by案例
- 6.组函数(avg(),sum(),max(),min(),count())、多行函数,分组数据(group by,求各部门的平均工资),分组过滤(having和where),sql优化
- oracle中的聚合函数count、max、min、sum、avg等等
- mysql中group by子句和聚合函数MAX(),MIN(),SUM(),AVG()等的使用
- Oracle基本分组查询group by的使用
- oracle sql合计结果信息使用分组的小问题
- 聚合函数和分组(sum(),count(),group by having)
- 使用聚合函数group by后面必须要带着所有要查询的列,但是我只想根据group by后面的第一个列进行分组,怎么办? [
- oracle的sys_connect_by_path及有关分组分类聚合函数使用
- 6.组函数(avg(),sum(),max(),min(),count())、多行函数,分组数据(group by,求各部门的平均工资),分组过滤(having和where),sql优化
- [置顶] oracle中的聚合函数count、max、min、sum、avg以及NVL函数的用法
- 在oracle中使用having关键字来限制你的分组结果
- SQL编程实例:Access数据库,两张表的统计,count、sum聚合函数的使用,iif的使用,group by的使用
- oracle 中如何在使用sum或其他聚合函数中,select查询条件处如何使用判断条件
- oracle的单行函数以及多行函数(聚合函数、分组函数)的使用
- 聚合函数(sum、count、max、min、avg)、where、group by、having的组合用法实例