MySQL分組查詢獲取每組最新的一條數(shù)據(jù)詳解(group?by)
業(yè)務(wù)場景:
最近項目中迭代一個舊的功能,再原有的設(shè)計上進(jìn)行功能拓展(因成本等原因,不考慮項目重構(gòu)),其中設(shè)計到了這么一個場景,同一個業(yè)務(wù) ID 在同一張表中有 N 條數(shù)據(jù),需要查詢出最新的那一條數(shù)據(jù)。
解決方案:
- 使用 group by id, 再按時間或者 id 降序,理論上就可以獲取最新的數(shù)據(jù)。
- 每個業(yè)務(wù) id 都去數(shù)據(jù)庫查詢一次,再按時間降序,最后 limit 1,就可以獲取到最新的數(shù)據(jù)(這個方案一般在項目中是不考慮的)。
- 使用 group by id。。。這里先賣個關(guān)子。
group by id 方案驗證:
test 表是主鍵自增的。
先查看數(shù)據(jù):
select id,kpa_id,progress from test where kpa_id=10;
執(zhí)行結(jié)果:
可知同一個業(yè)務(wù) ID 查詢結(jié)果有22條數(shù)據(jù)。
group by id 獲取最新的一條數(shù)據(jù),SQL如下:
select id,kpa_id,progress from test where kpa_id=10 group by kpa_id order by id desc;
執(zhí)行結(jié)果:
很明顯沒有獲取到最新的一條數(shù)據(jù),該方案不可行。
再次換一種SQL語法,如下:
select id,kpa_id,progress from (select * from test order by id desc)t where kpa_id=10 group by kpa_id;
執(zhí)行結(jié)果:
很明顯還是沒有獲取到最新的一條數(shù)據(jù),該方案仍然不可行,那怎么樣才可以實現(xiàn)呢?
那怎么樣才可以實現(xiàn)呢?
分析:既然要獲取最新的數(shù)據(jù),id自增,時間也是順序的,最新的數(shù)據(jù)是不是意味這就是 id 或者時間最大的那條數(shù)據(jù)?MySQL 中獲取最大的值使用 max()函數(shù)既可,下面我們來驗證一下。****
使用 max 函數(shù)獲取最大的 id,SQL 如下:
select id,kpa_id,progress from test where id in(select max(id) from test where kpa_id=10 group by kpa_id);
執(zhí)行結(jié)果如下:
結(jié)果顯而易見,獲取到了最大的那條數(shù)據(jù),功能已經(jīng)實現(xiàn),但是子查詢的效率比較低,我們還有沒有更高效的方法呢?
使用 inner join 內(nèi)連接,如下:
SQL如下:
select t1.id, t1.kpa_id, t1.progress from org_kpa_result t1 inner join ( select max(id) as id from org_kpa_result where kpa_id = 10 group by kpa_id) t2 on t1.id = t2.id;
執(zhí)行結(jié)果如下:
查詢結(jié)果是一樣的,但是我們都知道 inner join 內(nèi)連接的查詢效率要由于子查詢,故推薦使用該方法實現(xiàn)。
總結(jié)
到此這篇關(guān)于MySQL分組查詢獲取每組最新的一條數(shù)據(jù)的文章就介紹到這了,更多相關(guān)MySQL分組查詢每組最新一條數(shù)據(jù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MySQL 中 datetime 和 timestamp 的區(qū)別與選擇
MySQL 中常用的兩種時間儲存類型分別是datetime和 timestamp。如何在它們之間選擇是建表時必要的考慮。下面就談?wù)勊麄兊膮^(qū)別和怎么選擇,需要的朋友可以參考一下2021-09-09mysql 導(dǎo)出select語句結(jié)果到excel文件遇到問題及解決方法
這篇文章主要介紹了mysql 導(dǎo)出select語句結(jié)果到excel文件遇到問題及解決方法的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-09-09Shell下實現(xiàn)免密碼快速登陸MySQL數(shù)據(jù)庫的方法
這篇文章主要給大家介紹了在Shell下實現(xiàn)免密碼快速登陸MySQL數(shù)據(jù)庫的方法,文中通過示例代碼一步步介紹的非常詳細(xì),對大家具有一定的參考學(xué)習(xí)價值,需要的朋友們下面跟著小編來一起看看吧。2017-06-06MYSQL?SQL查詢近7天一個月的數(shù)據(jù)的操作方法
這篇文章主要介紹了MYSQL?SQL查詢近7天一個月的數(shù)據(jù)的操作方法,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-04-04MySQL 5.7.29 + Win64 解壓版 安裝教程圖文詳解
這篇文章主要介紹了MySQL 5.7.29 + Win64 解壓版 安裝教程,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-05-05