1.4 Oracle数据库学习教程-分组

Oracle数据库学习教程

分组函数

多行函数也叫组函数,作用与一组数据,并且对一组数据返回一个值.如AVG,COUNT,MAX,MIN,SUM等,操作的是一组数据,返回的是一个结果.


select sum(sal) from emp;  #对指定列的各行求和
select count(*) from emp;  #统计指定列的非空行
select avg(sal) from emp;  #求指定列的平均值

select sum(sal)/count(*) from emp;
# 这句也是求平均值,但是有NULL值的时候情况可能不同

#比如奖金,应该使用avg(comm)或sum(comm)/count(comm)

20211005235531


因为组函数都有滤空功能所以count(comm)只会选择有值的行

count(distinct job):查询工种

分组数据group by

select 列1,列二..,组函数().. group by 列一,列二...

注意: 在SELECT 列表中所有没有包含在组函数中的列,都必须在group by的后面出现。否则会报错.

逻辑上很容易理解:根据选择的列来进行分组,才符合我们的目的

20211006002327

过滤分组 Having

  • 不能在 WHERE 子句中使用组函数(注意)。
  • 可以在 HAVING 子句中使用组函数

select deptno,job,avg(sal) from emp group by deptno,job having avg(sal)>2000

20211006002750

相关文章

Java Oracle 结果集是Java语言中处理数据库查询结果的一种方...
Java AES和Oracle AES是现代加密技术中最常使用的两种AES加密...
Java是一种广泛应用的编程语言,具备可靠性、安全性、跨平台...
随着移动互联网的发展,抽奖活动成为了营销活动中不可或缺的...
Java和Oracle都是在计算机领域应用非常广泛的技术,他们经常...
Java 是一门非常流行的编程语言,它可以运行于各种操作系统上...