几个基本的分组函数

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/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/330796/viewspace-884554/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值