首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >PostgresSql查询

PostgresSql查询
EN

Stack Overflow用户
提问于 2021-04-26 11:56:44
回答 1查看 34关注 0票数 0

我想要获取在不同列中的"completed_order“活动之间发生的第一个"email”活动的activity_id。我尝试了下面的代码,但是我没有得到第一个“电子邮件”活动的id,而是得到了"completed_order“活动的id。

代码语言:javascript
复制
SELECT 
  activity_id,  
  customer ,  
  activity, 
  ts,
  case 
    when 
     activity = 'completed_order' and lead(activity) over (partition by customer order by ts) ='email'
    then        
    activity_id
  end as cndn

from activity_stream 
where customer in (
   select customer where customer = 'Lehmanns Marktstand' 
) 
order by ts

EN

回答 1

Stack Overflow用户

发布于 2021-04-26 12:05:59

我认为你需要使用这样的东西,但描述不是很清楚。在你的问题中添加一个想要的结果,如果是错误的,就删除评论

代码语言:javascript
复制
case 
 when 
  activity = 'email' and lag(activity) over (partition by customer order by ts) ='completed_order'
 then        
  lag(activity_id) over (partition by customer order by ts)
end as cndn

如果前一个活动是“已完成订单”,则会将前一行的活动id放在电子邮件行上。

编辑,严格地说,你想要的结果是由:

代码语言:javascript
复制
case 
 when 
  activity = 'completed_order' and lead(activity) over (partition by customer order by ts) ='email'
 then        
  lead(activity_id) over (partition by customer order by ts)
end as cndn
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67260653

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档