Oracle分析函数取平均值,7-oracle_分析函数(一)

article/2025/9/18 6:52:35

1.分组聚合函数

聚合函数主要有求和:sum();最大数:max();最小数:min();平均值:avg();统计数:count()等,在应用此类函数的时候,要么是从全集合来看或者从分组来看的。分组就是我们之前所说的维度,比如在成绩表中,我们需要按科目求出总成绩,最低成绩,最高成绩,平均成绩,以及人数。

select a.subject,

sum(a.score) all_score, --总成绩

min(a.score) min_score, --最低成绩

max(a.score) max_score, --最高成绩

avg(a.score) avg_score, --平均成绩

count(1) stu_cnt --人数

from t_score a

group by a.subject;

12e60bbbdece52d3b81af1ee54c6dc00.png

2.分组排序函数

row_number是用于分组排序的函数,在数据处理上常常会用到,实际工作中我们的TOP N;去重,这类场景中此函数很方便的实现我们的需求。

比如我们要按科目分类,对每个人的成绩从高到低排序:

select stu_no,

subject,

score,

row_number() over(partition by a.subject order by a.score desc) rn --排序

from t_score a;

82e6b99aa217f05560fd100493f43523.png

在row_number函数中,partition by则是按什么维度分组,如果不写这个则是按全集来分组,order by则是按什么排序,desc则表示倒序(从高到低),asc表示升序,默认是升序,可以不写。

比如我们需要求每个科目的前2名学生成绩信息。

select stu_no, subject, score, rn

from (select stu_no,

subject,

score,

row_number() over(partition by a.subject order by a.score desc) rn --排序

from t_score a) t

where t.rn <= 2;

f7324386e0c5cd7e1905b49fceda7d24.png

更多技术文章请关注公众号:BLT328


http://chatgpt.dhexx.cn/article/90qXfjWt.shtml

相关文章

oracle分析函数-RATIO_TO_REPORT() OVER()

1、RATIO_TO_REPORT()为比例函数 2、创建测试表&#xff0c;并插入数据 CREATE TABLE TEST_V( DEPTNO VARCHAR2(10), NAME VARCHAR2(10), SAL NUMBER ); 3、实例1&#xff1a;要求计算各部门工资合计&#xff0c;以及该工资合计占总工资的比例&#xff1a; SELECT TT.DEPT…

Oracle分析函数之Rank函数

本文主要讲述Oracle分析函数之Rank函数的用法 最近接触到Oracle这个功能强大而灵活的函数。这个函数特别适用于各种统计查询&#xff0c;下面就来说一说。 首先存在 product 表 SELECT p.create_time, p.name, p.service_evaluate_fee, p.product_type FROM product p 表数…

oracle 分析函数之分组求和、连续求和

最近在《sql cookbook》书上发现了名叫 分析函数 的东西&#xff0c;之前学 oracle 时没有印象&#xff0c;现在感觉其分析函数的功能相当强大、神奇&#xff0c; 就特意去找到了 chm 文档研究了一下&#xff0c;想要的朋友在本文末尾自行下载。 本文的例子都来源于 chm 文档…

在Oracle分析函数中使用FIRST_VALUE和LAST_VALUE

FIRST_VALUE and LAST_VALUE in Oracle Oracle中的FIRST_VALUE和LAST_VALUE These are Oracle analytical functions used to return the first value or the last value from a set of ordered rows. These functions can get the first value or the last value within a co…

Oracle 分析函数over,列转行函数pivot理解及综合运用(报表中的小计和合计)

1、Over函数&#xff08;分析统计函数&#xff09; 1.1语法 sum/avg/count() over(partition by ..)over()在什么条件之上;partition by 按哪个字段划分组&#xff1b; 1.2示例 SELECT E.ENAME,E.JOB,E.SAL,E.DEPTNO,SUM(E.SAL) OVER(PARTITION BY E.DEPTNO) SUM_SAL, …

oracle 百分位数,oracle分析函数 percent_rank, percentile_cont, percentile_disc

)*20=18 percentile_disc() PERCENTILE_DISC 这里就不做详细分析。 Syntax Purpose PERCENTILE_DISC is an inverse distribution function that assumes a discrete distribution model. It takes a percentile value and a sort specification and returns an element from t…

Oracle所有分析函数

Oracle分析函数 Oracle分析函数——函数列表 SUM &#xff1a;该函数计算组中表达式的累积和 MIN &#xff1a;在一个组中的数据窗口中查找表达式的最小值 MAX &#xff1a;在一个组中的数据窗口中查找表达式的最大值 AVG &#xff1a;用于计算…

oracle分析函数over(Partition by...)及开窗函数详解

说明&#xff1a;聚合函数&#xff08;如sum()、max()等&#xff09;可以计算基于组的某种聚合值&#xff0c;但是聚合函数对于某个组只能返回一行记录。若想对于某组返回多行记录&#xff0c;则需要使用分析函数。 1、rank()/dense_rank over(partition by ... order by ...) …

【Oracle】Oracle分析函数详解

Oracle数据库中的函数有多种&#xff0c;比如单行函数、聚合函数、对象引用函数、模型函数、OLAP函数等。本篇将详细介绍Oracle数据库中的分析函数。 一 分析函数概述 所谓分析函数&#xff0c;是基于一组数据行计算聚合值&#xff0c;其与聚合函数的不同之处在于&#xff0c…

oracle分析函数详解

一、Oracle分析函数 分析函数是什么&#xff1f; 分析函数是Oracle专门用于解决复杂报表统计需求的功能强大的函数&#xff0c;它可以在数据中进行分组然后计算基于组的某种统计值&#xff0c;并且每一组的每一行都可以返回一个统计值。 分析函数和聚合函数的不同之处是什么…

Oracle 分析函数练习实例

创建表 create table emp(deptno varchar2(20) ,empno varchar2(20),ename varchar(20),sal number );sql演示 –显示各部门员工的工资&#xff0c;并附带显示该部分的最高工资。 select e.deptno,e.empno,e.ename,e.sal,last_value(e.sal)over(partition by e.deptnoorder …

oracle ntile函数,Oracle分析函数ntile

Oracle分析函数ntile 有这么一个需求&#xff0c;将课程的成绩分成四个等级&#xff0c;为学生打A、B、C、D的绩效。 drop table course purge; create table course ( id number, grade number ); insert into course values(1,50); insert into course values(2,55); insert …

Oracle之分析函数

目录 1. 认识分析函数 1.1 什么是分析函数 1.2 分析函数和聚合函数的不同 1.3 分析函数的形式 2. 理解over()函数 2.1 两个order by 的执行机制 2.2 分析函数中的分组、排序、窗口 2.3 帮助理解over()的实例 3. 常见分析函数 3.1 演示表和数据的生成 3.2 first_valu…

Oracle中的分析函数

目录 1、理解什么是分析函数&#xff1f; 2、分析函数和聚合函数区别&#xff1f; 3、分析函数的语法&#xff1a; 4、常用的分析函数&#xff1a; 5、运用分析函数求相关累计问题 6、运用分析函数求相关排序问题 1. RANK()函数&#xff1a; 2. DENSE_RANK()函数&#…

常用Oracle分析函数大全

Oracle的分析函数功能非常强大&#xff0c;工作这些年来经常用到。这次将平时经常使用到的分析函数整理出来&#xff0c;以备日后查看。 我们拿案例来学习&#xff0c;这样理解起来更容易一些。 1、建表 1 2 3 4 5 6 7 8 9 10 create table earnings -- 打工赚钱表 ( ear…

oracle分析函数技术详解(配上开窗函数over())

一、Oracle分析函数入门 分析函数是什么?分析函数是Oracle专门用于解决复杂报表统计需求的功能强大的函数,它可以在数据中进行分组然后计算基于组的某种统计值,并且每一组的每一行都可以返回一个统计值。 分析函数和聚合函数的不同之处是什么?普通的聚合函数用…

Python 输出小数点后保留两位有效数字简便方法

用round(a,n) a代表变量&#xff0c;n代表想保留的小数点的个数&#xff1b;比如&#xff1a;

金额千位分隔符及保留2位小数

目录 numberObject.toFixed(num) 正则 $1、$2 正则 {} 正则 ? 正则 ?&#xff1a; 正则 正则 $ 正则 | numberObject.toFixed(num) NumberObject.toFixed(num) 方法把 Number 四舍五入为指定小数位数数字&#xff0c;返回 string 类型num 规定小数位数 0 ~ 20 之间…

chatgpt赋能python:Python中保留两位小数输出的方法:一个完整的指南

Python中保留两位小数输出的方法: 一个完整的指南 介绍 在Python编程中&#xff0c;有时候我们需要将数字保留到小数点后两位输出。例如&#xff0c;货币单位到分、科学计算等等。本文将介绍多种方法实现这个目标&#xff0c;包括Python的内置函数以及第三方库的函数。 方法…

c++ 保留2位小数输出

1.需要头文件<iomanip> 2.结果会经过四舍五入&#xff1b; 3.公式为 cout<<fixed<<setprecision(2)<<“要输出的变量”<<endl; !!!!!!setprecision()&#xff0c;括号中填几&#xff0c;就是保留几位小数&#xff1b;