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