欧美成人精品手机在线观看_69视频国产_动漫精品第一页_日韩中文字幕网 - 日本欧美一区二区

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

SQL實戰(zhàn):三種方法計算用戶最近兩次交易時間差

admin
2024年4月19日 16:13 本文熱度 774

下面分享使用三種方法計算用戶最近兩次交易時間差。

01 數(shù)據(jù)準備  

假設有一張表transactions,一列是用戶id(user_id),一列是交易時間(transaction_time),問用戶最近一次交易時間和倒數(shù)第二次交易時間之差,單位:秒。

示例表數(shù)據(jù)如下,具體建表及插入數(shù)據(jù)語句見文末附錄:

    

02 解題思路及SQL答案  

解題思路一:使用窗口函數(shù) — row_number() over()函數(shù)  

  • 在公共表達式中使用窗口函數(shù)ROW_NUMBER()為每個用戶的交易時間降序排列;

  • 使用自連接,將每個用戶的每次交易時間與其倒數(shù)第二次交易時間關聯(lián);

  • 篩選最近一次交易時間的記錄并計算最近一次交易時間與倒數(shù)第二次交易時間相差秒數(shù)。

SQL如下:

WITH RankedTransactions AS (                 SELECT                     user_id,                     transaction_time,                     ROW_NUMBER() OVER(PARTITION BY user_id ORDER BY transaction_time DESC) AS rn                 FROM                     transactions             )              SELECT                 t1.user_id,                     t1.transaction_time as latest_time,                    t2.transaction_time as second_latest_time,                TIMESTAMPDIFF(SECOND, t2.transaction_time, t1.transaction_time) AS time_difference_s             FROM                 RankedTransactions t1             JOIN                 RankedTransactions t2 ON t1.user_id = t2.user_id AND t2.rn = 2             WHERE                 t1.rn = 1;

結果如下:

解題思路二:使用公共表達式與表連接  

  • 第一步:找出每個用戶的最近一次交易時間 ;

  • 第二步:剔除最近一次交易時間后,找出每個用戶的最近一次交易時間(即倒數(shù)第二次);

  • 第三步:將兩個子查詢結果關聯(lián)起來,并計算時間差。

SQL如下:

-- 第一步:找出每個用戶的最近一次交易時間             WITH LatestTransactions AS (                 SELECT                     user_id,                     MAX(transaction_time) AS latest_time                 FROM                     transactions                 GROUP BY                     user_id             ),              -- 第二步:剔除最近一次交易時間后,找出每個用戶的最近一次交易時間(即倒數(shù)第二次)             SecondLatestTransactions AS (                 SELECT                     t.user_id,                     MAX(t.transaction_time) AS second_latest_time                 FROM                     transactions t                 LEFT JOIN                     LatestTransactions lt ON t.user_id = lt.user_id                    AND t.transaction_time = lt.latest_time                 WHERE                     lt.latest_time IS NULL OR t.transaction_time < lt.latest_time                 GROUP BY                     t.user_id             )              -- 第三步:將兩個子查詢結果關聯(lián)起來,并計算時間差             SELECT                 lt.user_id,                 latest_time,                second_latest_time,                TIMESTAMPDIFF(SECOND, slt.second_latest_time, lt.latest_time) AS time_difference             FROM                 LatestTransactions lt             JOIN                 SecondLatestTransactions slt ON lt.user_id = slt.user_id;

果如下:

解題思路三:窗口函數(shù)、子查詢結合法  

  • 第一步:對每個用戶的交易時間降序并位移獲取下一個交易時間,這時候最近一次交易時間和倒數(shù)第二次交易時間就在每一個用戶id的第一行;

  • 第二步:計算每個用戶的交易時間和其降序排列的下一個交易時間之差,并使用窗口函數(shù)對每個用戶的交易時間降序排列;

  • 第三步:篩選最近一次交易時間,即可得到計算后的結果。

SQL如下:

-- 第三步:篩選最近一次交易時間,即可得到計算后的結果            SELECT                user_id,                transaction_time,                       next_time,                time_difference            FROM                 (                -- 第二步:計算每個用戶的交易時間和其降序排列的下一個交易時間之差,并使用窗口函數(shù)對每個用戶的交易時間降序排列                SELECT                     user_id,                    transaction_time,                           next_time,                    TIMESTAMPDIFF(SECOND, next_time, transaction_time) AS time_difference,                    ROW_NUMBER() OVER(PARTITION BY user_id ORDER BY transaction_time DESC) AS rn                FROM                    -- 第一步:對每個用戶的交易時間降序并位移獲取下一個交易時間,這時候最近一次交易時間和倒數(shù)第二次交易時間就在每一個用戶id的第一行                    (                     SELECT                         user_id,                         transaction_time,                           LEAD(transaction_time) OVER (PARTITION BY user_id ORDER BY transaction_time DESC) AS next_time                     FROM                         transactions                     )a                )a            WHERE rn = 1            

結果如下:

附錄  

建表及插入數(shù)據(jù)語句:

CREATE TABLE transactions (              user_id INT,              transaction_time datetime            );             insert into transactions values            ('123',    '2024-01-01 15:30:30'),            ('123',    '2024-01-02 16:50:00'),            ('123',    '2024-01-03 16:51:38'),            ('123',    '2024-01-04 15:30:30'),            ('234',    '2024-01-01    16:51:38'),            ('234',    '2024-01-04 12:35:00'),            ('234',    '2024-01-07 09:58:00'),            ('345',    '2024-01-01 16:51:38'),            ('345',    '2024-01-02 15:30:30'),            ('345',    '2024-03-16 16:51:38'),            ('345',    '2024-03-17 12:35:00'),            ('345',    '2024-03-18 16:51:38'),            ('456',    '2024-03-04 16:51:38'),            ('456',    '2024-03-08 09:58:00'),            ('456',    '2024-03-09 12:35:00'),            ('456',    '2024-03-13 15:30:30');

以上就是本次的分享,感謝觀看!


該文章在 2024/4/19 16:13:42 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業(yè)的專業(yè)生產管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國內大量中小企業(yè)的青睞。
點晴PMS碼頭管理系統(tǒng)主要針對港口碼頭集裝箱與散貨日常運作、調度、堆場、車隊、財務費用、相關報表等業(yè)務管理,結合碼頭的業(yè)務特點,圍繞調度、堆場作業(yè)而開發(fā)的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業(yè)的高效ERP管理信息系統(tǒng)。
點晴WMS倉儲管理系統(tǒng)提供了貨物產品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質期管理,貨位管理,庫位管理,生產管理,WMS管理系統(tǒng),標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved