-- 假设我们有一个名为inventory.sku_daily_activity的表,包含SKU活跃度数据
-- 以下是计算SKU每日活跃度的SQL代码示例:
-- 创建一个临时表来存储每个SKU的累计活跃度
CREATE TEMPORARY TABLE active_sku_accumulative_daily_activity AS
SELECT
sku_id,
date,
SUM(daily_activity_count) OVER (PARTITION BY sku_id ORDER BY date) AS accumulative_activity
FROM
inventory.sku_daily_activity;
-- 计算每个SKU的最大累计活跃度日期
SELECT
sku_id,
MAX(date) AS max_activity_date
FROM
active_sku_accumulative_daily_activity
GROUP BY
sku_id;
-- 清理临时表
DROP TABLE active_sku_accumulative_daily_activity;
这段代码首先创建了一个临时表来存储每个SKU的累计活跃度数据,然后计算每个SKU的最大累计活跃度日期。最后,它删除了创建的临时表。这个过程展示了如何在PostgreSQL中处理基于窗口函数的复杂分析,并且是解决此类问题的一个很好的实践示例。