欢迎投稿

今日深度:

oracle_常用分组函数,oracle分组函数

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




oracle中的分组函数有什,具体怎使用?

常用的有:
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的,这个涉及到的东西就有很多了。一两句话说不清楚,如果有关于这方面的问题,可以发求助或追问。
 

oracle 分组函数

第二种理解不对,第二种是对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;



 

www.htsjk.Com true http://www.htsjk.com/shujukunews/4444.html NewsArticle oracle_常用分组函数,oracle分组函数 oracle_常用分组函数 ①分组函数 1.max(column):求最大,对数据类型没有要求,任意数据类型都可以 2.min(column):求最小,对数据类型没有要求,任意数据类型...
评论暂时关闭