亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MySQL分組查詢獲取每組最新的一條數(shù)據(jù)詳解(group?by)

 更新時間:2024年08月17日 10:12:45   作者:碼農(nóng)愛java  
在寫報表功能時遇到一個需要根據(jù)用戶id分組查詢最新一條錢包明細(xì)數(shù)據(jù)的需求,下面這篇文章主要給大家介紹了關(guān)于MySQL分組查詢獲取每組最新的一條數(shù)據(jù)的相關(guān)資料,需要的朋友可以參考下

業(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 的區(qū)別與選擇

    MySQL 中常用的兩種時間儲存類型分別是datetime和 timestamp。如何在它們之間選擇是建表時必要的考慮。下面就談?wù)勊麄兊膮^(qū)別和怎么選擇,需要的朋友可以參考一下
    2021-09-09
  • mysql 導(dǎo)出select語句結(jié)果到excel文件遇到問題及解決方法

    mysql 導(dǎo)出select語句結(jié)果到excel文件遇到問題及解決方法

    這篇文章主要介紹了mysql 導(dǎo)出select語句結(jié)果到excel文件遇到問題及解決方法的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-09-09
  • MYSQL神秘的HANDLER命令與實現(xiàn)方法

    MYSQL神秘的HANDLER命令與實現(xiàn)方法

    這篇文章主要介紹了MYSQL神秘的HANDLER命令與實現(xiàn)方法,需要的朋友可以參考下
    2016-07-07
  • MySQL獲取當(dāng)前時間、年月與年月日實例代碼

    MySQL獲取當(dāng)前時間、年月與年月日實例代碼

    日期和時間函數(shù)部分也是我們?nèi)粘9ぷ髦惺褂妙l率比較高的一部分,下面這篇文章主要給大家介紹了關(guān)于MySQL獲取當(dāng)前時間、年月與年月日的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-05-05
  • MYSQL 解鎖與鎖表介紹

    MYSQL 解鎖與鎖表介紹

    相對其他數(shù)據(jù)庫而言,MySQL的鎖機(jī)制比較簡單,其最顯著的特點是不同的存儲引擎支持不同的鎖機(jī)制
    2017-04-04
  • mysql用戶權(quán)限管理實例分析

    mysql用戶權(quán)限管理實例分析

    這篇文章主要介紹了mysql用戶權(quán)限管理,結(jié)合實例形式分析了mysql用戶權(quán)限管理概念、原理及用戶權(quán)限的查看、修改、刪除等操作技巧,需要的朋友可以參考下
    2020-04-04
  • Shell下實現(xiàn)免密碼快速登陸MySQL數(shù)據(jù)庫的方法

    Shell下實現(xiàn)免密碼快速登陸MySQL數(shù)據(jù)庫的方法

    這篇文章主要給大家介紹了在Shell下實現(xiàn)免密碼快速登陸MySQL數(shù)據(jù)庫的方法,文中通過示例代碼一步步介紹的非常詳細(xì),對大家具有一定的參考學(xué)習(xí)價值,需要的朋友們下面跟著小編來一起看看吧。
    2017-06-06
  • mysql忘記密碼怎么辦(windows linux)

    mysql忘記密碼怎么辦(windows linux)

    本文給大家介紹windows系統(tǒng)和linux系統(tǒng)下mysql忘記密碼怎么辦的相關(guān)資料,本文給出了合理的解決方案,非常好用,需要的朋友參考下
    2015-11-11
  • MYSQL?SQL查詢近7天一個月的數(shù)據(jù)的操作方法

    MYSQL?SQL查詢近7天一個月的數(shù)據(jù)的操作方法

    這篇文章主要介紹了MYSQL?SQL查詢近7天一個月的數(shù)據(jù)的操作方法,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-04-04
  • MySQL 5.7.29 + Win64 解壓版 安裝教程圖文詳解

    MySQL 5.7.29 + Win64 解壓版 安裝教程圖文詳解

    這篇文章主要介紹了MySQL 5.7.29 + Win64 解壓版 安裝教程,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-05-05

最新評論