欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

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

業(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)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MySQL 中 datetime 和 timestamp 的區(qū)別與選擇

    MySQL 中 datetime 和 timestamp 的區(qū)別與選擇

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

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

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

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

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

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

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

    MYSQL 解鎖與鎖表介紹

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

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

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

    Shell下實(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-06
  • mysql忘記密碼怎么辦(windows linux)

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

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

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

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

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

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

最新評(píng)論