【MySQL】【13】分組查詢取每組最新的一條數據


前言:獲取所有用戶填寫的最新一條地址數據

正文:

錯誤寫法:

mysql5.7時,子查詢的排序已經變為無效了

SELECT * FROM (SELECT * FROM address ORDER BY create_time DESC) a GROUP BY user_id

方法1:

此時子查詢就不光是排序,所以此時排序會生效,但有條數限制

SELECT * FROM (SELECT * FROM address ORDER BY create_time DESC LIMIT 10000) a GROUP BY user_id

方法2:

通過MAX函數獲取最新的時間和人員ID(分組條件),然后作為一張表和原來的數據進行聯查

注:這種方式如果有兩條數據的user_id和create_time都相等會查出來兩條數據,這種情況只能distinct一下了

SELECT t.* 
  FROM (SELECT user_id, max(create_time) as create_time FROM address GROUP BY user_id) a 
 INNER JOIN address t 
    ON t.user_id = a.user_id and t.create_time=a.create_time

參考博客:

MySQL分組查詢每組最新的一條數據(通俗易懂) - 劈天造陸 - 博客園
https://www.cnblogs.com/java-spring/p/11498457.html


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM