,count(*) 返回表中所有的行包括空行和重复的行。
select count(mgr) from emp;
查询有多少员工由经理管理。
count(mgr)返回表中所有表达式为非空的行。
2,AVE 返回表达式的平均值。
SUM返回表达式的总合。
1,count(*) 返回表中所有的行包括空行和重复的行。
select count(mgr) from emp;
查询有多少员工由经理管理。
count(mgr)返回表中所有表达式为非空的行。
2,AVE 返回表达式的平均值。
SUM返回表达式的总合。
select avg(sal) "Average salary",SUM(sal) "summary",COUNT(sal) "Record" from emp;
3, MIN返回表达式的最小值
MAX返回表达式的最大值
select MIN(sal) "Lowest Salary", MAX(sal) "Highest salary" from emp;
这两个函数还可以操作字符型和日期型数据。
假设老板想知道雇用第一个员工和启用最后的一个员工的日期。
select MIN(hiredate) "First Day",MAX(hiredate) "Last Day" from emp;
select job,AVG(sal) "Average salary" from emp group by job;
按职位分类,每类员工的平均工资。用以上的方法查。
注意,如果在珍上查询中使用了分组函数,任何不在分组函数中的列或表达式必须在GROUP BY 子句中。
select job,AVG(sal) "Average salary" from emp
group by job
order by "Average salary" DESC;
如果只想知道平均工资高于5000无的职位。
select job,AVG(sal) from emp
having AVG(sal)>5000
group by job;
当使用了having子句时,ORACLE系统处理的顺序如下:
one,首先对数据行(记录)进行分组
sec,把所得到的分组应用于分组函数
thr,最后显示满足HAVING子句所指定条件的结果。
分组函数可以嵌套
select MIN(AVG(sal)),MAX(AVG(sal)) from emp where job not like 'RPESI%'
group by job;
分组函数由于要进行全表扫描,对系统效率的冲击是不容忽视的
阅读(2434) | 评论(0) | 转发(0) |