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

PostgreSQL中FIRST_VALUE、LAST_VALUE、LAG 和 LEAD是窗口函数,允许返回在数据集的特定窗口(或分区)内访问行的相对位置

在PostgreSQL中,FIRST_VALUELAST_VALUELAGLEAD 是窗口函数(window functions),它们允许你在数据集的特定窗口(或分区)内访问行的相对位置。以下是对这些函数的详细解释和用法:

1. FIRST_VALUE

FIRST_VALUE 函数返回在指定窗口或分区内的第一行的值。它常用于获取每个组的起始值。

语法

FIRST_VALUE(column_name) OVER ([PARTITION BY partition_expression] ORDER BY sort_expression [ROWS or RANGE frame_clause])

示例

SELECT employee_id, department_id, salary, FIRST_VALUE(salary) OVER (PARTITION BY department_id ORDER BY salary) AS first_salary_in_dept
FROM employees;

这将为每个部门返回按工资排序后的第一(最低,如果升序)个员工的工资。

2. LAST_VALUE

LAST_VALUE 函数返回在指定窗口或分区内的最后一行的值。它常用于获取每个组的结束值。

语法

LAST_VALUE(column_name) OVER ([PARTITION BY partition_expression] ORDER BY sort_expression [ROWS or RANGE frame_clause])

示例

SELECT employee_id, department_id, salary, LAST_VALUE(salary) OVER (PARTITION BY department_id ORDER BY salary) AS last_salary_in_dept
FROM employees;

这将为每个部门返回按工资排序后的最后(最高,如果升序)个员工的工资。

3. LAG

LAG 函数返回窗口中当前行的前N行的值。它用于访问当前行的前几行的数据。

语法

LAG(column_name, offset, default_value) OVER ([PARTITION BY partition_expression] ORDER BY sort_expression)
  • offset:要回溯的行数(默认为1)。
  • default_value:如果回溯的行数超出窗口范围,则返回此默认值(可选)。

示例

SELECT employee_id, salary, LAG(salary, 1) OVER (ORDER BY salary) AS previous_salary
FROM employees;

这将为每行返回前一个员工的工资(按工资排序)。如果这是第一行,则 previous_salary 将为NULL,除非你指定了一个默认值。

4. LEAD

LEAD 函数返回窗口中当前行的后N行的值。它用于访问当前行的后几行的数据。

语法

LEAD(column_name, offset, default_value) OVER ([PARTITION BY partition_expression] ORDER BY sort_expression)
  • offset:要前瞻的行数(默认为1)。
  • default_value:如果前瞻的行数超出窗口范围,则返回此默认值(可选)。

示例

SELECT employee_id, salary, LEAD(salary, 1) OVER (ORDER BY salary) AS next_salary
FROM employees;

这将为每行返回下一个员工的工资(按工资排序)。如果这是最后一行,则 next_salary 将为NULL,除非你指定了一个默认值。

注意事项

  • 这些函数通常与 OVER 子句一起使用,其中可以指定分区(PARTITION BY)和排序(ORDER BY)。
  • 如果不指定 frame_clause(即 ROWSRANGE),则默认使用整个分区作为窗口。
  • LAGLEAD 函数中的 offset 默认为1,表示前一行或后一行。
  • 如果 LAGLEAD 函数中的回溯或前瞻行数超出窗口范围,并且没有指定 default_value,则结果将为NULL。

通过这些函数,你可以灵活地访问和操作数据行之间的相对位置,从而进行更复杂的数据分析和处理。

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

相关文章:

  • 树莓派之旅-第一天 系统的烧录和设置
  • 数据库工程师进阶秘籍:云计算基础知识题目精选与答案(附PDF)
  • 【HAProxy】如何在Ubuntu下配置HAProxy服务器
  • C#编写的盘符图标修改器 - 开源研究系列文章
  • (四)配置有线网口、SSH登陆、文件传输以及运行交叉编译程序测试
  • 离线的方式:往Maven的本地仓库里安装依赖
  • 《深入浅出HTTPS​​​​​​​​​​​​​​​​​》读书笔记(22):密钥协商算法
  • kubernetes学习-Service
  • Springcloud项目-前后端联调(一)
  • 洛谷P1525 [NOIP2010 提高组] 关押罪犯(种子并查集基础)
  • 【算法刷题指南】模拟
  • 学习笔记078——Java Properties类使用详解
  • 若依使用 Undertow 替代 Tomcat 容器
  • 多输入多输出 | Matlab实现WOA-CNN鲸鱼算法优化卷积神经网络多输入多输出预测
  • Elasticsearch:基础概念
  • Spring MVC的@ResponseBody与@RequestBody
  • 智能商业分析 Quick BI
  • LUA基础语法
  • SpringBoot的pom.xml文件中,scope标签有几种配置?
  • Leetcode729: 我的日程安排表 I
  • 青少年编程与数学 02-006 前端开发框架VUE 02课题、创建工程
  • Redis的生态系统和社区支持
  • Tomcat解析
  • UML之组合与聚合
  • 数据结构理论篇(期末突击)
  • 《一文读懂PyTorch核心模块:开启深度学习之旅》
  • 摆脱Zotero存储限制:WebDAV结合内网穿透打造个人文献管理云平台
  • Flutter封装一个三方ViewPager学习
  • 服务器数据恢复—离线盘数超过热备盘数导致raidz阵列崩溃的数据恢复
  • nginx-nginx的缓存集成