如何解决来自同一组 SQL 的同一列中日期的 DateDiff
我需要获取同一用户的订单与上一个订单之间的天数差异
订单表:
getBirthdays
我不知道所以任何帮助都会非常感激!!
提前致谢:)
解决方法
您可以使用窗口函数。它看起来像这样:
select o.*,datediff(activation_time,lag(activation_time) over (partition by customer_id order by activation_time) as Days_since_last_order
from orders o;
请注意,对于最早的激活,这将返回 NULL
。我不知道为什么你的数据有“2”。
我更喜欢 NULL
作为最早的日期,但如果您想要 0
,您可以使用:
select o.*,lag(activation_time,1,activation_time) over (partition by customer_id order by activation_time
) as Days_since_last_order
from orders o;
也就是说,给 LAG()
添加一个默认参数。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。