喜欢寡浮 2023-12-26 20:34 采纳率: 0%
浏览 16

大数据仓库与建模技术例题

现有order_info订单表,表结构如下所示。按要求完成(1)-(2)小题。
order_id user_id user_name order_date order_amount
1 1001 小元 2022-01-01 10
2 1002 小海 2022-01-02 15
3 1001 小元 2022-02-03 23
4 1002 小海 2022-01-04 29
5 1001 小元 2022-01-05 46

(1)统计每个用户截止每次下单的累计下单总额。(8分)
(2)统计每个用户每次下单距离上次下单相隔的天数(首次下单按0天算

  • 写回答

1条回答 默认 最新

  • 哎呀呀不会啊 2024-01-02 08:30
    关注
    
    SELECT   
        user_id,   
        user_name,   
        order_date,   
        SUM(order_amount) AS cumulative_order_amount  
    FROM   
        order_info  
    GROUP BY   
        user_id, user_name, order_date  
    ORDER BY   
        user_id, order_date;
    
    
    WITH OrderedOrders AS (  
        SELECT   
            user_id,   
            user_name,   
            order_date,   
            SUM(order_amount) OVER (PARTITION BY user_id, user_name ORDER BY order_date) AS cumulative_order_amount,  
            LAG(order_date) OVER (PARTITION BY user_id, user_name ORDER BY order_date) AS previous_order_date  
        FROM   
            order_info  
    )  
    SELECT   
        user_id,   
        user_name,   
        order_date,   
        CASE WHEN previous_order_date IS NULL THEN 0 ELSE DATEDIFF(day, previous_order_date, order_date) END AS days_since_previous_order  
    FROM   
        OrderedOrders;
    
    
    评论
    1人已打赏

报告相同问题?

问题事件

  • 创建了问题 12月26日

悬赏问题

  • ¥50 求恶意流量检测系统搭建教程( C++ python C)
  • ¥15 mmseqs内存报错
  • ¥15 vika文档如何与obsidian同步
  • ¥15 华为手机相册里面的照片能够替换成自己想要的照片吗?
  • ¥15 陆空双模式无人机飞控设置
  • ¥15 sentaurus lithography
  • ¥100 求抖音ck号 或者提ck教程
  • ¥15 关于#linux#的问题:子进程1等待子进程A、B退出后退出(语言-c语言)
  • ¥20 web页面如何打开Outlook 365的全球离线通讯簿功能
  • ¥15 io.jsonwebtoken.security.Keys