Oracle 分析函数RANK(),ROW_NUMBER(),LAG()等的使用方法

Oracle分析函数RANK(),ROW_NUMBER(),LAG()等的使用方法,需要的朋友可以参考下。

ROW_NUMBER() OVER (PARTITION BY COL1 ORDER BY COL2)

表示根据COL1分组,在分组内部根据 COL2排序
而这个值就表示每组内部排序后的顺序编号(组内连续的唯一的)

RANK() 类似,不过RANK 排序的时候跟派名次一样,可以并列2个第一名之后 是第3名

LAG 表示 分组排序后 ,组内后面一条记录减前面一条记录的差,第一条可返回 NULL

BTW: EXPERT ONE ON ONE 上讲的最详细,还有很多相关特性,文档看起来比较费劲

row_number()和rownum差不多,功能更强一点(可以在各个分组内从1开时排序)
rank()是跳跃排序,有两个第二名时接下来就是第四名(同样是在各个分组内)
dense_rank()l是连续排序,有两个第二名时仍然跟着第三名。
相比之下row_number是没有重复值的
lag(arg1,arg2,arg3):
arg1是从其他行返回的表达式
arg2是希望检索的当前行分区的偏移量。是一个正的偏移量,时一个往回检索以前的行的数目。
arg3是在arg2表示的数目超出了分组的范围时返回的值。

SQL> set pagesize 100;
SQL> select rownum from emp;

ROWNUM
———-
1
2
3
4
5
6
7
8
9
10
11
12
13
14

已选择14行。

已用时间: 00: 00: 00.10
SQL> select deptno,row_number() over(partition by deptno order by sal) from emp order by deptno;

DEPTNO ROW_NUMBER()OVER(PARTITIONBYDEPTNOORDERBYSAL)
———- ———————————————
10 1
2
3

20 1
2
3
4
5

30 1
2
3
4
5
6

已选择14行。

已用时间: 00: 00: 00.41
SQL> select deptno,rank() over (partition by deptno order by sal) from emp order by deptno;

DEPTNO RANK()OVER(PARTITIONBYDEPTNOORDERBYSAL)
———- —————————————
10 1
2
3

20 1
2
3
4
4

30 1
2
2
4
5
6

已选择14行。

已用时间: 00: 00: 00.21
SQL> select deptno,dense_rank() over(partition by deptno order by sal) from emp order by deptno;

DEPTNO DENSE_RANK()OVER(PARTITIONBYDEPTNOORDERBYSAL)
———- ———————————————
10 1
2
3

20 1
2
3
4
4

30 1
2
2
3
4
5

已选择14行。

已用时间: 00: 00: 00.20
SQL> select deptno,ename,sal,lag(ename,1,null) over(partition by deptno order by ename) from emp ord
er by deptno;

DEPTNO ENAME SAL LAG(ENAME,
———- ———- ———- ———-
10 CLARK 2450
KING 5000 CLARK
MILLER 1300 KING

20 ADAMS 1100
FORD 3000 ADAMS
JONES 2975 FORD
SCOTT 3000 JONES
SMITH 800 SCOTT

30 ALLEN 1600
BLAKE 2850 ALLEN
JAMES 950 BLAKE
MARTIN 1250 JAMES
TURNER 1500 MARTIN
WARD 1250 TURNER

已选择14行。

已用时间: 00: 00: 00.31
SQL> select deptno,ename,sal,lag(ename,2,’example’) over(partition by deptno order by ename) from em
p order by deptno;

DEPTNO ENAME SAL LAG(ENAME,
———- ———- ———- ———-
10 CLARK 2450 example
KING 5000 example
MILLER 1300 CLARK

20 ADAMS 1100 example
FORD 3000 example
JONES 2975 ADAMS
SCOTT 3000 FORD
SMITH 800 JONES

30 ALLEN 1600 example
BLAKE 2850 example
JAMES 950 ALLEN
MARTIN 1250 BLAKE
TURNER 1500 JAMES
WARD 1250 MARTIN

已选择14行。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/896289.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月28日 17:56:02
下一篇 2025年11月28日 18:00:35

相关推荐

  • Java中MANIFEST.MF的作用 详解清单文件

    manifest.mf是java中jar文件的元数据配置文件,位于meta-inf目录下,用于定义版本、主类、依赖路径等关键信息。1. 它允许指定入口类,使jar可直接运行;2. 通过class-path管理依赖,减少类加载冲突;3. 可配置安全权限,如设置沙箱运行;4. 常见属性包括manifes…

    2025年12月5日 java
    000
  • Java中枚举类型怎么定义 掌握Java枚举的定义和常用方法

    java中定义枚举类型使用enum关键字,例如public enum weekday { monday, tuesday,…};枚举可包含字段和方法,如添加中文名称字段及获取方法;可在switch语句中使用,确保覆盖所有值;常用方法包括values()、valueof()、ordinal…

    2025年12月4日 java
    000
  • 韩国星巴克:请勿带台式电脑和打印机等大型设备进店

    感谢网友 c%ignore_a_1%je_he 的线索分享! 8 月 14 日消息,据《FORTUNE(财富)》8 月 12 日报道,在办公空间紧张的韩国,越来越多远程办公者选择将星巴克门店当作临时办公室。 为应对这一趋势,韩国星巴克已出台新规,禁止顾客携带大型工作设备入店,例如台式电脑、打印机等。…

    2025年12月4日
    200
  • Lambda表达式内抛出异常必须注意哪些函数式接口的限制?

    lambda表达式抛出异常时,关键在于所用函数式接口是否允许抛出检查型异常。1. 若接口方法未声明 throws,则lambda不能直接抛出检查型异常;2. 可在lambda内部使用 try-catch 捕获处理异常;3. 可自定义声明 throws 的函数式接口以支持检查型异常抛出;4. 也可通过…

    2025年12月4日 java
    000
  • 苹果将​​重组销售部门,任职27年企业业务主管将离职

    ☞☞☞AI 智能聊天, 问答助手, AI 智能搜索, 免费无限量使用 DeepSeek R1 模型☜☜☜ %ign%ignore_a_1%re_a_1%公司负责企业销售和西欧市场的高管计划在今年晚些时候离职,这是该公司任职时间最长的管理人员中最新的一位离职。 据知情人士透露,负责苹果西欧及全球企业销…

    2025年12月4日
    000
  • Objects.requireNonNull()如何替代显式的if-null抛异常代码?

    使用objects.requirenonnull()可以更简洁地处理null值检查。1. 它是java标准库提供的工具,用于检查对象是否为null,并在为null时抛出nullpointerexception;2. 相比传统if-null判断,它减少代码量并提高可读性;3. 与断言不同,它始终执行检…

    2025年12月4日 java
    100
  • js如何实现数组快速排序 3种快速排序算法实现方案分享

    %ignore_a_1%是一种基于“分而治之”策略的高效排序算法,其核心是选定一个基准值,将数组分为两部分,使得左边元素小于基准值,右边元素大于基准值,然后递归地对左右子数组排序。文章介绍了三种javascript实现方案:1. lomuto分区方案选择最后一个元素为基准,通过指针i划分边界,优点简…

    2025年12月4日 web前端
    000
  • java中的实例是什么 实例的概念及其与类的关系

    java中的实例是类的具体对象。实例是类的具体实现,类定义对象的属性和行为,而实例则是这些属性的具体化。一个类可以有多个实例,每个实例独立且通过构造函数创建,实例可以调用类中的方法。 Java中的实例是什么?实例的概念及其与类的关系 Java中的实例,这个问题问得好,实例在Java编程中是一个非常基…

    2025年12月4日
    100
  • linux中的makefile是什么

    在linux中,makefile是一个工程文件的编译规则,描述了整个工程的编译和链接等规则;其中包含了哪些文件需要编译,哪些文件不需要编译,哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重建等等。 本教程操作环境:linux5.9.8系统、Dell G3电脑。 1、什么是 Makefile M…

    2025年12月4日
    000
  • js如何实现图片颜色提取 js图片主色提取的3种算法

    %ign%ignore_a_1%re_a_1%的核心方法包括:1.平均颜色法;2.中位数值法;3.k-means聚类法。平均颜色法通过计算所有像素rgb的平均值,实现简单但易受极端值影响。中位数值法则对rgb通道分别排序并取中位数,能部分消除异常值影响。k-means聚类法则通过聚类算法将颜色分组,…

    2025年12月4日 web前端
    000
  • Java中Comparator怎么用 详解比较器的多种实现方式

    如何使用comparator实现自定义排序?1.使用匿名内部类创建comparator,例如通过实现compare()方法根据字符串长度排序;2.使用lambda表达式简化写法,如(s1,s2)->s1.length()-s2.length();3.使用comparator.comparing…

    2025年12月4日 java
    000
  • linux怎么查看系统是几位的

    查看方法:1、在终端执行“file /sbin/init”命令进行查看;2、在终端执行“uname -a”命令进行查看;3、在终端执行“getconf WORD_BIT”命令进行查看。 本教程操作环境:linux5.9.8系统、Dell G3电脑。 查看linux是几位的操作系统 方法1: 终端输入…

    2025年12月4日
    000
  • Java中类初始化的时机及静态代码块执行顺序

    java类初始化在特定时机触发,包括创建实例、访问静态成员、反射调用、子类初始化及启动类加载。静态代码块在类加载时执行且仅一次,其执行顺序与静态变量按代码顺序进行,构造器则在对象创建时调用并先执行父类构造器。类加载器影响初始化时机,不同加载器可导致同一类多次初始化,而其层次结构决定加载顺序和可见性。…

    2025年12月4日 java
    000
  • kali linux是什么

    Kali Linux是一个基于Debian的Linux发行版,旨在实现高级渗透测试和安全审计;它包含数百种工具,适用于各种信息安全任务,如渗透测试、安全研究、计算机取证和逆向工程等。 本教程操作环境:Kali Linux 2021.2系统、Dell G3电脑。 什么是Kali Linux? Kali…

    2025年12月4日
    100
  • oracle/mysql拼接值遇到的坑及双竖线||和concat怎么使用

    %ign%ignore_a_1%re_a_1% mysql 拼接值遇到的坑 双竖线 || concat || “||” 在oracle中是拼接值,但在mysql中是“或”的意思。 where name like ‘%’ || ‘Tony’ || ‘%’ 所以推荐使用concat() concat()…

    数据库 2025年12月4日
    000
  • Java中多播怎么实现 掌握组播通信机制

    java中实现多播的核心在于使用datagramsocket和multicastsocket,前者用于普通udp通信,后者专门处理多播数据包的发送与接收。具体步骤如下:1. 创建multicastsocket实例;2. 通过joingroup()加入多播组(地址范围为224.0.0.0至239.25…

    2025年12月4日 java
    000
  • JavaFX 8 全屏缩放应用:解决 BorderPane 重复添加子节点问题

    本文旨在解决 JavaFX 8 应用中实现全屏缩放时遇到的 `BorderPane` 重复添加子节点的问题。通过分析错误原因和提供正确的代码示例,帮助开发者避免类似错误,并实现期望的全屏缩放效果。文章重点在于理清 `BorderPane` 的使用方式,并提供清晰的布局策略。 在 JavaFX 应用开…

    2025年12月4日
    000
  • VSCode怎么激活代码提示_VSCode开启和配置智能代码提示功能教程

    答案:VSCode代码提示不工作通常因缺少语言扩展或配置不当。需安装对应语言扩展(如Python、C#),确保文件类型正确,配置jsconfig.json/tsconfig.json或settings.json,排除无关目录,并重启语言服务器以提升准确性。 VSCode的代码提示功能,也就是我们常说…

    2025年12月4日
    000
  • 2025年一季度方盒子车型哪款卖得好?iCAR V23进前三

    据智车派获悉,%ignore_a_1%第一季度,国内的方盒子车型市场依旧火爆,销量排行榜已揭晓。其中,哈弗大狗以23784辆的销量雄踞榜首,领先于第二名的捷途旅行者,其销量为15598辆,成为榜单中唯一突破两万辆大关的车型,显示出其强大的市场吸引力。 ☞☞☞AI 智能聊天, 问答助手, AI 智能搜…

    2025年12月4日
    000
  • Java中如何实现监控 掌握Prometheus

    要实现java应用监控与prometheus集成,关键在于暴露指标并配置抓取。首先,使用micrometer暴露java应用指标,通过添加io.micrometer依赖支持prometheus;其次,在spring boot中配置management.endpoints.web.exposure.i…

    2025年12月4日 java
    000

发表回复

登录后才能评论
关注微信