oracle 组函数
一、组函数嵌套
ORACLE中规定,组函数嵌套只能嵌两层。其实多层嵌套并没有实际的用途,因此ORACLE没有提供组函数的多层嵌套。但是,单行函数是可以多层嵌套的。
二、
1、Oracle包含以下组函数
-AVG([DISTINCT|ALL]n) 返回平均值,忽略空值
-COUNT({*|[DISTINCT|ALL]}expr) 返回记录的数量,用*包含空值,否则不包含空值
-MAX([DISTINCT|ALL]expr) 返回最大值,忽略空值
-MIN([DISTINCT|ALL]expr) 返回最小值,忽略空值
-SUM([DISTINCT|ALL]n) 返回总值,忽略空值
-STDDEV([DISTINCT|ALL]x) 返回标准差,忽略空值
-VARIANCE([DISTINCT|ALL]x) 返回统计方差,忽略空值
2、AVG和SUM的用法
-可以对数值型数据使用AVG和SUM
例:
SELECT AVG(sal),SUM(sal)
FROM EMP
WHERE job LIKE 'SALES%';
3、MIN和MAX的用法
-MIN和MAX可以用于任何数据类型
例:
SELECT MIN(hiredate),MAX(hiredate)
FROM emp;
结果:
MIN(HIREDATE) MAX(HIREDATE)
17-12月-80 23-5月 -87
4、
COUNT的用法
1)COUNT(*)返回表中行的总数
例:
SELECT COUNT(*)
FROM emp
WHERE deptno=30;
结果:
COUNT(*)
6
2)COUNT(expr)返回非空行的数量
例:
SELECT COUNT(comm)
FROM emp
WHERE deptno=30;
结果:
COUNT(*)
4
5.组函数和空值
1)组函数会忽略列中的空值
例:
SELECT AVG(comm)
FROM emp;
结果:
AVG(COMM)
550
2)NVL函数可以使组函数强制包含含有空值的记录
例:
SELECT AVG(NVL(comm,0))
FROM emp;
结果:
AVG(NVL(COMM,0))
157.142857
6、创建数据组
SELECT column,group_function(column)
FROM table
[WHERE condition]
[GROUP BY group_by_expression]
[OEDER BY column];
-通过GROUP BY子句将表中的记录划分成若干个小组
-GROUP BY子句中必须包含指定的列
-GROUP BY子句中不能使用列的别名
-当使用GROUP BY子句时Orale服务器会自动对结果集合默认按GROUP BY子句所指定的列升序排列
-在SELECT列表中除了组函数外,所有列都必须包含在GROUP BY子句中
例:
SELECT deptno,AVG(sal)
FROM emp
GROUP BY deptno;
结果:
DEPTNO AVG(SAL)
10 2916.66667
20 2175
30 1566.66667
-GROUP BY所指定的列并不是必须出现在SELECT列表中
例:
SELECT AVG(sal)
FROM emp
GROUP BY deptno;
结果:
AVG(SAL)
2916.66667
2175
1566.66667
7.按多个列分组
例:
SELECT deptno,job,sum(sal)
FROM emp
GROUP BY deptno,job;
结果:
DEPTNO JOB SUM(SAL)
10 CLERK 1300
10 MANAGER 2450
10 PRESIDENT 5000
20 CLERK 1900
20 ANALYST 6000
20 MANAGER 2975
30 CLERK 950
30 MANAGER 2850
30 SALESMAN 5600
8.使用组函数的非法查询
例:
SELECT dept,COUNT(ename)
FROM emp;
结果:
ERROR 位于第 1 行:
ORA-00937: 非单组分组函数
纠正:
SELECT dept,COUNT(ename)
FROM emp
GROUP BY deptno;
结果:
DEPTNO COUNT(ENAME)
10 3
20 5
30 6
9.限制组结果
使用HAVING子句限制组
-对记录分组
-在分组的基础上应用组函数
-与HAVING子句匹配的结果才输出
SELECT column,group_function
FROM table
[WHERE condition]
[GROUP BY group_by_expression]
[HAVING group_condition]
[ORDER BY column];
例1:
SELECT deptno,max(sal)
FROM emp
WHERE max(sal)>2900
GROUP BY deptno;
结果:
ERROR 位于第 3 行:
ORA-00934: 此处不允许使用分组函数
纠正:
SELECT deptno,max(sal)
FROM emp
GROUP BY deptno
HAVING max(sal)>2900;
结果:
DEPTNO MAX(SAL)
10 5000
20 3000
例2:
SELECT job,SUM(sal) PAYROLL
FROM emp
WHERE job NOT LIKE 'SALES%'
GROUP BY job
HAVING SUM(sal)>5000
ORDER BY SUM(sal);
结果:
JOB PAYROLL
ANALYST 6000
MANAGER 8275
10.组函数嵌套
-与单行函数不同,组函数只能嵌套两层
例:显示平均薪水的最大值
SELECT max(avg(sal))
FROM emp
GROUP BY deptno;
结果:
MAX(AVG(SAL))
2916.66667
练习
1.使用emp表显示所有雇员的最多、最少、总和、平均薪水
SELECT ename,MAX(sal),MIN(sal),SUM(sal),AVG(sal)
FROM emp;
2.显示emp表中不同部门编号的数量
SELECT COUNT(DISTINCT deptno)
FROM emp;
3.在emp表中根据job列分组显示雇员的最多、最少、总和、平均薪水
SELECT job,MAX(sal),MIN(sal),SUM(sal),AVG(sal)
FROM emp
GROUP BY job;
4.使用emp表显示job名、每组最多、最少、总和、平均薪水
要求:按job列分组,ename列的名字不是以A开头,且任何组的最少薪水大于1600
SELECT job,MAX(sal),MIN(sal),SUM(sal),AVG(sal)
FROM emp
WHERE ename NOT LIKE 'A%'
GROUP BY job
HAVING MIN(sal)>1600
5.显示部门名和每个部门的累计薪水,要求每个部门的累计薪水大于3000
SELECT dname,SUM(sal)
FROM emp e,dept d
WHERE e.deptno=d.deptno
GROUP BY dname
HAVING SUM(sal)>3000;
6.显示每个部门、每个岗位的最高及最低薪水
SELECT deptno,job,MAX(sal),MIN(sal)
FROM emp
GROUP BY deptno,job;
三、sql聚合函数嵌套问题
问题:我现在要查的是top client(买东西总和加起来最多的)
所以我输了 SELECT C.CLIENTNO, C.CNAME, MAX(SUM(P.AMOUNT))
FROM CLIENT C,PURCHASE P
WHERE C.CLIENTNO=P.CLIENTNO
GROUP BY C.CLIENTNO,C.CNAME;
提示说不是单组分组函数,所以 问题应该是出在 max(sum(p.amount))上吧,应该如何分开来写啊
解答:
with t as (SELECT job, deptno, sum(sal) sal FROM emp group by job, deptno)select * from t where sal = (select max(sal) from t)oracle 组函数的更多相关文章
- Oracle组函数、多表查询、集合运算、数据库对象(序列、视图、约束、索引、同义词)等
count组函数:(过滤掉空的字段) select count(address),count(*) from b_user max() avg() min(),sum() select sum(age ...
- 数据库Oracle组函数和分组函数
组函数: 组函数操作行集,给出每组的结果.组函数不象单行函数,组函数对行的集合进行操作,对每组给出一个结果.这些集合可能是整个表或者是表分成的组. 组函数与单行函数区别: 单行函数对查询到每个结果集做 ...
- Oracle 组函数count()
1.count() 函数的参数除了可以是字段值和表达式外,还可以是“ * ”.如果是字段值或表达式,则忽略空值且考虑重复值:如果是“ * ”,则计算所有的行,也包括空值.如果要查询某字段非重复值的个数 ...
- oracle(sql)基础篇系列(一)——基础select语句、常用sql函数、组函数、分组函数
花点时间整理下sql基础,温故而知新.文章的demo来自oracle自带的dept,emp,salgrade三张表.解锁scott用户,使用scott用户登录就可以看到自带的表. #使用ora ...
- Netsuite Formula > Oracle函数列表速查(PL/SQL单行函数和组函数详解).txt
PL/SQL单行函数和组函数详解 函数是一种有零个或多个参数并且有一个返回值的程序.在SQL中Oracle内建了一系列函数,这些函数都可被称为SQL或PL/SQL语句,函数主要分为两大类: 单行函数 ...
- oracle数据库之组函数
组函数也叫聚合函数,用来对一组值进行运算,并且可以返回单个值 常见的组函数: (1)count(*),count(列名) 统计行数:找到所有不为 null 的数据来统计行数 (2)avg(列名) ...
- Oracle常用sql语句(二)之组函数、多表查询
DML(数据操纵语言) INSERT .UPDATE. DELETE 插入操作:INSERT: 语法: INSERT INTO 表名(列名1,列名2 ...)VALUES(列值1,列值2...); 注 ...
- oracle(sql)基础篇系列(一)——基础select语句、常用sql函数、组函数、分组函数
花点时间整理下sql基础,温故而知新.文章的demo来自oracle自带的dept,emp,salgrade三张表.解锁scott用户,使用scott用户登录就可以看到自带的表. #使用oracle用 ...
- ORACLE SQL 组函数【weber出品必属精品】
组函数:对一组数据进行加工,每组数据返回一个值 常用的组函数:count() avg() max() min() sum() count()函数 1. count(*) :返回总共的行 ...
随机推荐
- Delphi动态事件深入分析(对象方法在调用的时候会传递一个隐含的Self指针,而该指针的值在EAX中。即左边第一个参数)
Delphi动态事件深入分析 2009-2-7 作者:不得闲核心提示:本实验证明了在类中方法的调用时候,所有的方法都隐含了一个Self参数,并且该参数作为对象方法的第一个参数传递... 首先做一个空窗 ...
- jenkins集成自动化部署插件(一) deploy-plugin
在实际情况中项目构建成功,特别是web项目构建成功是需要将war放到对应的服务上面,进行运行(测试的阶段可能就是发布到测试服务器上面)这样只需要指定构建的触发策略就可以自动构建以及部署,省去不少人工的 ...
- gdb与adb相关命令总结
在使用gdb与adb时需要注意一些类似于权限的问题,比如设备需要root,设备root后命令行下需要 切换用户到root用户下操作,又比如相关的目录或文件是否有足够的权限等等,总结为如下: (以下示例 ...
- servlet实现文件下载
之前没怎么用过这个,这次项目中用到了,于是总结一下: 应该说主要注意三方面: 1.写一个servlet 2.在web.xml中配置这个servlet 3.页面上调用这个servlet 第一: 写 ...
- 等宽格子堆砌 js
<!doctype html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- log log4net用代码记录日志
log4net 用代码记录日志 今天在开发项目的时候,遇到跨域调用log4net中的类,出现了一个bug,提示LogImpl未标记可序列化,此时,我靠,麻烦了,这个类又不是咱们自己的,改源码我想应该 ...
- QQ2013手工去广告
QQ的广告令人讨厌,虽然网上有很多去广告补丁或者是去广告版,但是总是害怕有被盗号的风险,那除了付费会员还有其他什么方法可以安全的去除qq广告吗?显然有,那就是手动去广告. 很简单,不会比使用去广告补丁 ...
- javascript中对象的属性的特性
1.ES5的属性特性包括下面六个: configurable: 表示能否通过delete来删除属性从而重新定义属性,能够修改属性的特性,默认为true enumberable: 表示是否能通过for- ...
- 字符串 —— String?StringBuffer?StringBuilder?
字符串常用的操作就是拼接,特别是SQL语句的拼接. 做了个简单的试验,它们之间的差别惊人! StringBuffer: public void testStringBuffer() { long st ...
- poj -2229 Sumsets (dp)
http://poj.org/problem?id=2229 题意很简单就是给你一个数n,然后选2的整数幂之和去组成这个数.问你不同方案数之和是多少? n很大,所以输出后9位即可. dp[i] 表示组 ...