ITPub博客

首页 > 应用开发 > IT综合 > 几个基本的分组函数

几个基本的分组函数

原创 IT综合 作者:mfm088 时间:2006-12-17 22:14:22 0 删除 编辑

1,count(*) 返回表中所有的行包括空行和重复的行。

select count(mgr) from emp;

查询有多少员工由经理管理。

count(mgr)返回表中所有表达式为非空的行。

2,AVE 返回表达式的平均值。

SUM返回表达式的总合。

[@more@]

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;

分组函数由于要进行全表扫描,对系统效率的冲击是不容忽视的

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/330796/viewspace-884554/,如需转载,请注明出处,否则将追究法律责任。

上一篇: 论语其一
请登录后发表评论 登录
全部评论

注册时间:2012-01-14

  • 博文量
    98
  • 访问量
    1025057