这是他们订购的第一个商人的客户? SQL问题
我正在努力解决这个sql问题:
对于每个商家,找出他们有多少订单和首次订单。首次订单是从客户的角度来看的,是客户下的第一个订单。换句话说,有多少顾客是他们第一次向该商家订购的? 输出商户名称、订单总数以及首次下单的订单数。
订单 |
---|
id int |
customer_id int |
Mercury_id int |
order_timestamp datetime |
n_items int |
Total_amount_earned float |
商家 |
---|
id int |
name varchar |
Category varchar |
order_timestamp datetime |
zipcode int |
这是我到目前为止所拥有的:
with first_time_orders as (
select customer_id, rank() over (partition by merchant_id order by order_timestamp) as first_order
from orders
group by customer_id, merchant_id
)
select *
from first_time_orders;
I am struggling with this sql question:
For each merchant, find how many orders and first-time orders they had. First-time orders are meant from the perspective of a customer and are the first order that a customer ever made. In order words, for how many customers was this the first-ever merchant they ordered with?
Output the name of the merchant, the total number of their orders and the number of these orders that were first-time orders.
orders |
---|
id int |
customer_id int |
merchant_id int |
order_timestamp datetime |
n_items int |
total_amount_earned float |
merchants |
---|
id int |
name varchar |
category varchar |
order_timestamp datetime |
zipcode int |
this is what i have so far:
with first_time_orders as (
select customer_id, rank() over (partition by merchant_id order by order_timestamp) as first_order
from orders
group by customer_id, merchant_id
)
select *
from first_time_orders;
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
您可以
用cter 尝试一下
(选择,
dense_rank()over(customer_id订单分区订单dimestamp)h
来自doordash_orders)
选择 *来自(选择Merchant_ID,count()GB的cter Group by Merchant_id)h
加入
(从cter中选择“商品_id”,计数(*)gbb,其中h = 1组由erthant_id)p
在h.merchant_id上= p.merchant_id
you can try this
with cter as
(select ,
dense_rank() over (partition by customer_id order by order_timestamp ) h
from doordash_orders)
select * from (select merchant_id,count() gb from cter group by merchant_id) h
join
(select merchant_id,count(*) gbb from cter where h=1 group by merchant_id) p
on h.merchant_id=p.merchant_id