Chinaunix首页 | 论坛 | 博客
  • 博客访问: 194010
  • 博文数量: 54
  • 博客积分: 1542
  • 博客等级: 上尉
  • 技术积分: 537
  • 用 户 组: 普通用户
  • 注册时间: 2006-05-24 11:51
文章分类

全部博文(54)

文章存档

2017年(1)

2008年(2)

2007年(20)

2006年(31)

我的朋友

分类: Oracle

2007-01-05 12:52:55

,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) |
0

上一篇:oracle常用视图

下一篇:tnsname.ora的介绍

给主人留下些什么吧!~~