oracle_常用分组函数,oracle分组函数
oracle_常用分组函数
①分组函数
1.max(column):求最大值,对数据类型没有要求,任意数据类型都可以
2.min(column):求最小值,对数据类型没有要求,任意数据类型都可以
3.avg(column):返回column不为null的平均值,对数据类型有要求,只能针对number类型(数字类型)
4.sum(column):返回column不为null的总和,对数据类型有要求,只能针对number类型(数字类型)
5.count(column):返回column不为null的记录数,对数据类型没有要求,任意数据类型都可以
注:组函数忽略空值
COUNT(DISTINCT expr)返回expr非空且不重复的记录总数
②分组
分组数据: GROUP BY 子句语法
可以使用GROUP BY子句将表中的数据分成若干组
在SELECT 列表中所有未包含在组函数中的列都应该包含在 GROUP BY 子句中。
包含在 GROUP BY 子句中的列不必包含在SELECT 列表中
所有包含于SELECT 列表中,而未包含于组函数中的列都必须包含于 GROUP BY 子句中。
不能在 WHERE 子句中使用组函数。
可以在 HAVING 子句中使用组函数
③过滤分组: HAVING 子句
使用 HAVING 过滤分组:
1.行已经被分组。
2.使用了组函数。
3.满足HAVING 子句中条件的分组将被显示。
④组函数嵌套
max(avg(salary))
常用的有:
COUNT() 返回查寻的行数
例如:select count(*) from table;
MAX() 返回表达式的最大值
例如:select a, max(b) from table group by a;
MIN() 返回表达式的最小值
例如:select a, min(b) from table group by a;
SUM() 返回表达式的总合
例如:select a, sum(b) from table group by a;
AVG() 返回表达式的平均值
例如:select a, avg(b) from table group by a;
此外还有分析函数over,是用来处理复杂sql的,这个涉及到的东西就有很多了。一两句话说不清楚,如果有关于这方面的问题,可以发求助或追问。
第二种理解不对,第二种是对a和b同时进行分组,你看一下下面的例子你就知道:
create table test
(a int,
b int,
c int);
insert into test values(1,2,1)
insert into test values(1,2,2);
insert into test values(1,3,1);
insert into test values(1,3,2);
insert into test values(2,2,1);
insert into test values(2,2,2);
insert into test values(3,2,3);
insert into test values(4,2,4);
select a ,count(*) "统计" from test t
group by t.a ;
select a ,b,count(*) "统计" from test t
group by t.a ,t.b;