当前位置: 首页 > news >正文

SQL中的LAG函数与LEAD函数用法

LAG:函数用于获取结果集中当前行之前的某一行的值

LAG (scalar_expression [,offset] [,default]) OVER ([partition_by_clause ] order_by_clause )
-----汉字解释
LAG (字段 [,偏移量默认为1] [,如果没有值时候默认值]) OVER ( [ partition_by 字段 ] order_by 字段 )

Lead:函数用于获取结果集中当前行之后的某一行的值

LEAD (scalar_expression [,offset] [,default]) OVER ([partition_by_clause ] order_by_clause )
-----汉字解释
LEAD (字段 [,偏移量默认为1] [,如果没有值时候默认值]) OVER ( [ partition_by 字段 ] order_by 字段 )

原数据

select * from tmporder_id | order_date | customer_name |  price   | product_id | order_status 
----------+------------+---------------+----------+------------+--------------1 | 2020-07-28 | Jark          | 50.50000 |        102 | f2 | 2020-07-29 | Sally         | 15.00000 |        105 | f3 | 2020-07-30 | Edward        | 25.25000 |        106 | f4 | 2020-07-31 | Edward        | 25.25000 |        106 | f
select *,lag(order_id,1,99) over(partition by order_status order by order_Date) from tmp;order_id | order_date | customer_name |  price   | product_id | order_status | lag 
----------+------------+---------------+----------+------------+--------------+-----1 | 2020-07-28 | Jark          | 50.50000 |        102 | f            |  992 | 2020-07-29 | Sally         | 15.00000 |        105 | f            |   13 | 2020-07-30 | Edward        | 25.25000 |        106 | f            |   24 | 2020-07-31 | Edward        | 25.25000 |        106 | f            |   3
------------------------------------------------------------------------------------
select *,lead(order_id,1,99) over(partition by order_status order by order_Date) from tmp;order_id | order_date | customer_name |  price   | product_id | order_status | lead 
----------+------------+---------------+----------+------------+--------------+------1 | 2020-07-28 | Jark          | 50.50000 |        102 | f            |    22 | 2020-07-29 | Sally         | 15.00000 |        105 | f            |    33 | 2020-07-30 | Edward        | 25.25000 |        106 | f            |    44 | 2020-07-31 | Edward        | 25.25000 |        106 | f            |   99

 lag和lead的用法中order by的顺序都是asc的,也就是这两个可以使用降序排序的写法就能等于另一个了,

lag()over(order by 字段 desc)=lead over(order by 字段)

lead()over (order by 字段 desc)=lag over(order by 字段)

http://www.lryc.cn/news/350059.html

相关文章:

  • 数据结构------二叉树经典习题1
  • 汇聚荣:拼多多长期没有流量如何提高?
  • Chrome的常用操作总结
  • dvwa靶场 JavaScript Attacks(js攻击)全难度教程(附代码分析)
  • Flutter 中的 checkboxListTile 小部件:全面指南
  • 前馈神经网络FNN、多层感知机MLP和反向传播推导
  • QML笔记八
  • 运维别卷系列 - 云原生监控平台 之 00.prometheus 监控汇总
  • 信息系统安全与对抗-网络侦查技术与网络扫描技术(期末复习简答题)
  • 【python量化交易】—— Alpha选股策略 - Qteasy自定义交易策略【附源码】
  • 简单记录下:Navicat 导出表结构至 Excel
  • 黑马基于Web-socket的java聊天室基本解析
  • 【操作系统期末速成】​内存管理|内存的装入模块在装入内存的方式|分配管理方式|页面置换算法|页面置换
  • 图和网络笔记
  • 请求外部系统报错
  • 电路板维修【四】
  • (程序设计语言)传值、传引用
  • 一次基类类型对象无法被传递问题的分析
  • windows设置Redis服务后台自启动
  • 掌握Linux常用命令,扫平面试需求障碍
  • c语言之文件打开模式
  • 与禹老师学前端vue3学习汇总
  • Linux网络编程——HTTP协议的理解与运用
  • RestTemplate接口请求发送json、form数据格式以及处理接口错误状态码400 null
  • 《Python编程从入门到实践》day29
  • UIKit之图片浏览器
  • 如何查看SNMP设备的OID
  • 什么?你设计接口什么都不考虑?
  • 2024年3月 青少年等级考试机器人理论真题二级
  • C语言学习【printf函数和scanf函数】