lead()/lag()函数

2023-12-04 20:38
文章标签 函数 lag lead

本文主要是介绍lead()/lag()函数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

lag与lead函数是跟偏移量相关的两个分析函数

通过这两个函数可以在一次查询中取出同一字段的前N行的数据(lag)和后N行的数据(lead)作为独立的列,从而更方便地进行进行数据过滤
该操作可代替表的自联接,且效率更高

lag()/lead()
  lead(field, num, defaultvalue)
    field: 需要查找的字段
    num: 往后查找的num行的数据
    defaultvalue: 没有符合条件的默认值over()
  表示lag()与lead()操作的数据都在over()的范围内,里面可以使用以下子句
    partition by 语句(用于分组)
    order by 语句()用于排序)
  如:over(partition by a order by b) 表示以a字段进行分组,再以b字段进行排序,对数据进行查询

示例:

  数据集

with dataset as (select '001' as id, 'Jack' as name, '大连' as city, '100' as sales from dualunion allselect '002' as id, 'Tom' as name, '大连' as city, '98' as sales from dualunion allselect '003' as id, 'John' as name, '大连' as city, '125' as sales from dualunion allselect '004' as id, 'Larry' as name, '大连' as city, '130' as sales from dualunion allselect '005' as id, 'Levi' as name, '沈阳' as city, '115' as sales from dualunion allselect '006' as id, 'Tomas' as name, '沈阳' as city, '170' as sales from dualunion allselect '007' as id, 'Jimmy' as name, '沈阳' as city, '130' as sales from dualunion allselect '008' as id, 'Robert' as name, '大连' as city, '103' as sales from dualunion allselect '009' as id, 'William' as name, '大连' as city, '118' as sales from dualunion allselect '010' as id, 'Joe' as name, '沈阳' as city, '108' as sales from dual
)

 获取当前记录的员工id,及销量仅次于该员工的员工id

select t.id ,lead(t.id, 1, null) over(order by t.sales desc)  next_record_id, t.name,t.city,t.sales
from ( select id,name,city,to_number(sales) as sales from dataset ) t 

结果:

获取当前记录的员工id,及销量仅高于该员工的员工id

select t.id ,lag(t.id, 1, null) over(order by t.sales desc)  next_record_id, t.name,t.city,t.sales
from ( select id,name,city,to_number(sales) as sales from dataset ) t   

结果:

获取当前记录的员工id,及按照城市分组且销量仅次于该员工的员工id

select t.id ,lead(t.id, 1, null) over(partition by t.city order by t.sales desc)  next_record_id, t.name,t.city,t.sales
from ( select id,name,city,to_number(sales) as sales from dataset ) t 

结果:

获取当前记录的员工id,及按照城市分组且销量仅次于该员工的员工id(销量差小于10的忽略) 

select tt.*
from
(select t.id, t.name,t.sales,lead(t.sales,1, null) over(partition by t.city order by sales desc ) next_sales, (t.sales - lead(t.sales,1, null) over(partition by t.city order by sales desc )) as diff,t.city from ( select id,name,city,to_number(sales) as sales from dataset ) t 
) tt
where tt.diff >= 10 or tt.diff is null

结果:

这篇关于lead()/lag()函数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/454834

相关文章

C++ Sort函数使用场景分析

《C++Sort函数使用场景分析》sort函数是algorithm库下的一个函数,sort函数是不稳定的,即大小相同的元素在排序后相对顺序可能发生改变,如果某些场景需要保持相同元素间的相对顺序,可使... 目录C++ Sort函数详解一、sort函数调用的两种方式二、sort函数使用场景三、sort函数排序

C语言函数递归实际应用举例详解

《C语言函数递归实际应用举例详解》程序调用自身的编程技巧称为递归,递归做为一种算法在程序设计语言中广泛应用,:本文主要介绍C语言函数递归实际应用举例的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录前言一、递归的概念与思想二、递归的限制条件 三、递归的实际应用举例(一)求 n 的阶乘(二)顺序打印

C/C++错误信息处理的常见方法及函数

《C/C++错误信息处理的常见方法及函数》C/C++是两种广泛使用的编程语言,特别是在系统编程、嵌入式开发以及高性能计算领域,:本文主要介绍C/C++错误信息处理的常见方法及函数,文中通过代码介绍... 目录前言1. errno 和 perror()示例:2. strerror()示例:3. perror(

Kotlin 作用域函数apply、let、run、with、also使用指南

《Kotlin作用域函数apply、let、run、with、also使用指南》在Kotlin开发中,作用域函数(ScopeFunctions)是一组能让代码更简洁、更函数式的高阶函数,本文将... 目录一、引言:为什么需要作用域函数?二、作用域函China编程数详解1. apply:对象配置的 “流式构建器”最

Android Kotlin 高阶函数详解及其在协程中的应用小结

《AndroidKotlin高阶函数详解及其在协程中的应用小结》高阶函数是Kotlin中的一个重要特性,它能够将函数作为一等公民(First-ClassCitizen),使得代码更加简洁、灵活和可... 目录1. 引言2. 什么是高阶函数?3. 高阶函数的基础用法3.1 传递函数作为参数3.2 Lambda

C++中::SHCreateDirectoryEx函数使用方法

《C++中::SHCreateDirectoryEx函数使用方法》::SHCreateDirectoryEx用于创建多级目录,类似于mkdir-p命令,本文主要介绍了C++中::SHCreateDir... 目录1. 函数原型与依赖项2. 基本使用示例示例 1:创建单层目录示例 2:创建多级目录3. 关键注

C++中函数模板与类模板的简单使用及区别介绍

《C++中函数模板与类模板的简单使用及区别介绍》这篇文章介绍了C++中的模板机制,包括函数模板和类模板的概念、语法和实际应用,函数模板通过类型参数实现泛型操作,而类模板允许创建可处理多种数据类型的类,... 目录一、函数模板定义语法真实示例二、类模板三、关键区别四、注意事项 ‌在C++中,模板是实现泛型编程

kotlin的函数forEach示例详解

《kotlin的函数forEach示例详解》在Kotlin中,forEach是一个高阶函数,用于遍历集合中的每个元素并对其执行指定的操作,它的核心特点是简洁、函数式,适用于需要遍历集合且无需返回值的场... 目录一、基本用法1️⃣ 遍历集合2️⃣ 遍历数组3️⃣ 遍历 Map二、与 for 循环的区别三、高

C语言字符函数和字符串函数示例详解

《C语言字符函数和字符串函数示例详解》本文详细介绍了C语言中字符分类函数、字符转换函数及字符串操作函数的使用方法,并通过示例代码展示了如何实现这些功能,通过这些内容,读者可以深入理解并掌握C语言中的字... 目录一、字符分类函数二、字符转换函数三、strlen的使用和模拟实现3.1strlen函数3.2st

MySQL中COALESCE函数示例详解

《MySQL中COALESCE函数示例详解》COALESCE是一个功能强大且常用的SQL函数,主要用来处理NULL值和实现灵活的值选择策略,能够使查询逻辑更清晰、简洁,:本文主要介绍MySQL中C... 目录语法示例1. 替换 NULL 值2. 用于字段默认值3. 多列优先级4. 结合聚合函数注意事项总结C