PostgreSQL使用``ag()''窗口函数更新查询

PostgreSQL使用``ag()''窗口函数更新查询,第1张

PostgreSQL使用``ag()''窗口函数更新查询

from
子句中使用子查询:

update table_turnover     set closing_balance = (ttprev.prev_closing_balance + ttprev.turnover)     from (select tt.*,      lag(closing_balance) over (partition by product order by week_number) as prev_closing_balance          from table_turnover tt         ) ttprev    where ttprev.product = tt.product and ttprev.week_number = tt.week_number and          week_number > 0;

或者,如果您想在中使用子查询

select

update table_turnover     set closing_balance = (turnover +     (select tt2.closing_balance       from table_turnover tt2      where tt2.product = tt.product and tt2.week_number = tt.week_number - 1     )    )    where week_number > 0;

为了提高性能(在任何一个版本上),您都希望在上建立索引

table_turnover(product, week_number,closing_balance)



欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/4934112.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-11-13
下一篇 2022-11-13

发表评论

登录后才能评论

评论列表(0条)

保存