【数据库】【sql】如何用SQL实现跨行计算

【背景】

这里的跨行计算不是指整体聚合类的函数比如SUM等的功能,而是指递归算法。

比如我接到有需求,有一个结果字段需要是目前所有行该字段的和,这是属于递归类的算法,SQL中如何实现呢?

【方法】

可以使用窗口函数,比如:

sql 复制代码
SELECT
  sales_date,
  sales_amount,
  LAG(sales_amount) OVER (ORDER BY sales_date) AS prev_sales_amount
FROM
  sales_data;

这里面的LAG代表前一行的值,顺序由Order By指定。这里是直接获得了上一行的值,如果再和本行进行计算,就可以实现各类递归算法。

除了LAG,通用SQL中还有LEAD,用法差不多,只不过代表下一行的值。

【注意】

不同的数据库,关键词和语法会有所变化,但是大差不差,心法是差不多的。

比如PostgreSQL还有FIRST_VALUE函数等。

相关推荐
Full Stack Developme5 分钟前
PostgreSQL interval 转换为 int4 (整数)
数据库·postgresql
larance7 分钟前
FastAPI + SQLAlchemy 数据库对象转字典
数据库·fastapi
哆啦A梦是一只狸猫8 分钟前
SQL Server缩小日志文件.ldf的方法(适用于开发环境)
数据库·sql·sqlserver
CHEN5_021 小时前
时序数据库选型“下半场”:从性能竞赛到生态博弈,四大主流架构深度横评
数据库·人工智能·ai·架构·时序数据库
hqxstudying2 小时前
MyBatis 和 MyBatis-Plus对比
java·数据库·mysql·mybatis
DarkAthena3 小时前
AI生成技术报告:GaussDB与openGauss的HTAP功能全面对比
数据库·gaussdb
DemonAvenger4 小时前
高效JOIN操作:多表关联查询技巧与实战经验分享
数据库·mysql·性能优化
小云数据库服务专线5 小时前
GaussDB 数据库架构师修炼(十八) SQL引擎-分布式计划
数据库·数据库架构·gaussdb
秋已杰爱6 小时前
Redis分布式锁
数据库·redis·分布式
烟锁池塘柳07 小时前
【R语言】R语言中 rbind() 与 merge() 的区别详解
sql·r语言