mysql如何查詢兩個日期之間最大的連續登入天數_Mysql

來源:互聯網
上載者:User

前言

最近工作中遇到一個需求,是根據使用者連續記錄天數來計算的,求出使用者在一段時間內最大的連續記錄時間,例如在 2016-01-01 和 2016-01-28 之間,如果使用者在3號和4號都記錄了,那麼連續記錄天數為2,如果使用者在6號-10號每日都記錄了,那麼最大連續記錄天數為5.

拿到這個需求的時候,說實話有點懵,第一想到的就是在代碼中去統計,會用到迴圈,想到那麼多個使用者,並且時間跨度也有點大,比如15年到16年,兩年時間,想想就有點恐怖。

解決方案

然後就把這個需求跟朋友說了,朋友也覺得有點難搞,後來通過網上一篇文章有了一些小思路。但是看得也是一知半解的,雖然經常寫 sql 語句,但也是常用的那些增刪改查,像這樣使用的方式根本沒用過,過了會,朋友又扔給我一條 sql 語句,就在該文章的基礎上進行了修改,以符合我的項目需求的語句。

SELECT *FROM (SELECT *   FROM (       SELECT        uid,        max(days)   lianxu_days,        min(login_day) start_date,        max(login_day) end_date       FROM (SELECT           uid,           @cont_day :=           (CASE           WHEN (@last_uid = uid AND DATEDIFF(created_ts, @last_dt) = 1)            THEN             (@cont_day + 1)           WHEN (@last_uid = uid AND DATEDIFF(created_ts, @last_dt) < 1)            THEN             (@cont_day + 0)           ELSE            1           END)                       AS days,           (@cont_ix := (@cont_ix + IF(@cont_day = 1, 1, 0))) AS cont_ix,           @last_uid := uid,           @last_dt := created_ts                login_day          FROM (SELECT              uid,              DATE(created_ts) created_ts             FROM plan_stage             WHERE uid != 0             ORDER BY uid, created_ts) AS t,           (SELECT            @last_uid := '',            @last_dt := '',            @cont_ix := 0,            @cont_day := 0) AS t1         ) AS t2       GROUP BY uid, cont_ix       HAVING lianxu_days > 10      ) tmp   ORDER BY lianxu_days DESC) ntmpGROUP BY uid;

查詢出來的結果如下圖所示:

如果要查看單個人的,那麼將 sql 語句中的 uid !=0 改成具體的值即可。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家學習或者使用sql語句能有所協助,如果有疑問大家可以留言交流。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.