如何在SQL中使用Lag函数

avatar
作者
猴君
阅读量:0

LAG() 函数是 SQL 中的一个窗口函数,它可以访问结果集中当前行之前的某一行

以下是 LAG() 函数的基本语法:

LAG(column_name, offset, default_value) OVER (PARTITION BY partition_column ORDER BY order_column) 

参数说明:

  • column_name:要操作的列名。
  • offset:(可选)指定要访问的行与当前行之间的偏移量。默认值为 1,表示访问前一行。
  • default_value:(可选)当偏移量超出范围时,返回的默认值。如果没有提供此参数,则返回 NULL。
  • PARTITION BY partition_column:(可选)将结果集划分为多个分区,每个分区内的行将单独进行排序和计算。
  • ORDER BY order_column:指定对分区内的行进行排序的列。

以下是一个使用 LAG() 函数的示例。假设我们有一个名为 sales_data 的表,其中包含以下列:sales_date、product_id 和 daily_sales。我们想要查询每个产品在每天的销售额以及前一天的销售额。

SELECT     product_id,     sales_date,     daily_sales,     LAG(daily_sales, 1, 0) OVER (PARTITION BY product_id ORDER BY sales_date) AS previous_day_sales FROM     sales_data ORDER BY     product_id,     sales_date; 

这个查询将返回一个结果集,其中包含每个产品在每天的销售额以及前一天的销售额。如果前一天没有销售额数据,则返回默认值 0。

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!