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

Mysql查詢最近一條記錄的sql語(yǔ)句(優(yōu)化篇)

 更新時(shí)間:2018年05月26日 10:44:32   作者:一只阿木木  
這篇文章主要介紹了Mysql查詢最近一條記錄的sql語(yǔ)句,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧

下策——查詢出結(jié)果后將時(shí)間排序后取第一條

select * from a 
where create_time<="2017-03-29 19:30:36" 
order by create_time desc
limit 1

這樣做雖然可以取出當(dāng)前時(shí)間最近的一條記錄,但是一次查詢需要將表遍歷一遍,對(duì)于百萬(wàn)以上數(shù)據(jù)查詢將比較費(fèi)時(shí);limit是先取出全部結(jié)果,然后取第一條,相當(dāng)于查詢中占用了不必要的時(shí)間和空間;還有如果需要批量取出最近一條記錄,比方說(shuō):“一個(gè)訂單表,有用戶,訂單時(shí)間,金額,需要一次性查詢所有用戶的最近的一條訂單記錄”,那么每個(gè)用戶一次查詢就要做一次整表的遍歷,數(shù)據(jù)大的情況下,時(shí)間將會(huì)以指數(shù)形式增長(zhǎng),不能投入實(shí)際使用。

中策——查詢排序后group by

select * from (
  select * from a
  where create_time<="2017-03-29 19:30:36" 
  order by create_time desc
)  group by user_id

后來(lái)發(fā)現(xiàn)使用group by 可以根據(jù)group by 的參數(shù)列分組,但返回的結(jié)果只有一條,仔細(xì)觀察發(fā)現(xiàn)group by是將分組后的第一條記錄返回。時(shí)間在查詢后默認(rèn)是順序排列,因此需要先將時(shí)間倒序排列,方可取出距離當(dāng)前最近一條。

這樣查詢實(shí)際上還是進(jìn)行了兩次查詢,雖然時(shí)間上相比第一個(gè)方法有了質(zhì)的飛躍,但是還可以進(jìn)一步優(yōu)化。

上策——將max() 方法和group by結(jié)合使用

select *,max(create_time) from a
where create_time<="2017-03-29 19:30:36" 
group by user_id

這句可以理解為將結(jié)果集根據(jù)user_id分組,每組取time最大一條記錄。這樣就很好的實(shí)現(xiàn)了批量查詢最近記錄,并且僅僅需要遍歷一次表,即使在數(shù)據(jù)量巨大的情況下也可以在很短的時(shí)間查出結(jié)果。

 擴(kuò)展:

現(xiàn)在有一張資產(chǎn)設(shè)備表:base_assets_turn

查詢資產(chǎn)的最新保管人

注:假設(shè)資產(chǎn)編號(hào)   ASSETS_ID=254

下策:

select * from base_assets_turn 
where ASSETS_ID = 254
order by create_time desc
limit 1

中策:

select * from ( select * from base_assets_turn 
where ASSETS_ID = 254
order by create_time desc) tt GROUP BY tt.ASSETS_ID;

上策:

那么上策該如何書(shū)寫(xiě)呢,歡迎留言!

以上所述是小編給大家?guī)?lái)的Mysql查詢最近一條記錄的sql語(yǔ)句(優(yōu)化篇),希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)歡迎給我留言!

相關(guān)文章

  • MySQL默認(rèn)字符集設(shè)置詳情

    MySQL默認(rèn)字符集設(shè)置詳情

    這篇文章主要介紹了MySQL默認(rèn)字符集設(shè)置詳情,在MySQL?8.0版本之前,默認(rèn)字符集為latin1?,utf8字符集指向的是utf8mb3,更多相關(guān)內(nèi)容介紹,需要的小伙伴可以參考一下
    2022-09-09
  • MySQL事務(wù)管理的作用詳解

    MySQL事務(wù)管理的作用詳解

    事務(wù)就是一組DML語(yǔ)句組成,這些語(yǔ)句在邏輯上存在相關(guān)性,這一組DML語(yǔ)句要么全部成功,要么全部失敗,是一個(gè)整體。MySQL提供一種機(jī)制,保證我們達(dá)到這樣的效果。事務(wù)還規(guī)定不同的客戶端看到的數(shù)據(jù)是不相同的
    2022-08-08
  • SQL實(shí)現(xiàn)LeetCode(175.聯(lián)合兩表)

    SQL實(shí)現(xiàn)LeetCode(175.聯(lián)合兩表)

    這篇文章主要介紹了SQL實(shí)現(xiàn)LeetCode(175.聯(lián)合兩表),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • 關(guān)于MySQL中savepoint語(yǔ)句使用時(shí)所出現(xiàn)的錯(cuò)誤

    關(guān)于MySQL中savepoint語(yǔ)句使用時(shí)所出現(xiàn)的錯(cuò)誤

    這篇文章主要介紹了關(guān)于MySQL中savepoint語(yǔ)句使用時(shí)所出現(xiàn)的錯(cuò)誤,字符串出現(xiàn)e時(shí)所產(chǎn)生的問(wèn)題也被作為MySQL的bug進(jìn)行過(guò)提交,需要的朋友可以參考下
    2015-05-05
  • MySQL?Server?層四個(gè)日志詳解

    MySQL?Server?層四個(gè)日志詳解

    這篇文章主要介紹了MySQL?Server?層四個(gè)日志,包括錯(cuò)誤日志,查詢?nèi)罩?,二進(jìn)制日志及慢查詢?nèi)罩?,本文結(jié)合示例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2022-03-03
  • MySQL中的唯一性約束與NULL詳解

    MySQL中的唯一性約束與NULL詳解

    這里記錄的是很久之前的一個(gè) bug 了,主要給大家介紹了關(guān)于MySQL中唯一性約束與NULL的相關(guān)資料,文中介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。
    2017-05-05
  • 關(guān)于MySQL Memory存儲(chǔ)引擎的相關(guān)知識(shí)

    關(guān)于MySQL Memory存儲(chǔ)引擎的相關(guān)知識(shí)

    這篇文章主要介紹了關(guān)于MySQL Memory存儲(chǔ)引擎的相關(guān)知識(shí),幫助大家更好的理解和使用MySQL數(shù)據(jù)庫(kù),感興趣的朋友可以了解下
    2020-11-11
  • MySQL8.0鎖等待排查的實(shí)現(xiàn)

    MySQL8.0鎖等待排查的實(shí)現(xiàn)

    MySQL8.0相較于5.7版本在鎖等待排查方面發(fā)生了顯著變化,原有的INNODB_LOCKS和INNODB_LOCK_WAITS表被移除,本篇文章將結(jié)合這些改動(dòng),介紹 MySQL 8.0 版本如何排查鎖等待問(wèn)題,感興趣的可以了解一下
    2024-09-09
  • MySQL分類排名和分組TOP N實(shí)例詳解

    MySQL分類排名和分組TOP N實(shí)例詳解

    大家好,本篇文章主要講的是MySQL分類排名和分組TOP N實(shí)例詳解,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下
    2022-01-01
  • mysql分頁(yè)時(shí)offset過(guò)大的Sql優(yōu)化經(jīng)驗(yàn)分享

    mysql分頁(yè)時(shí)offset過(guò)大的Sql優(yōu)化經(jīng)驗(yàn)分享

    mysql分頁(yè)是我們?cè)陂_(kāi)發(fā)經(jīng)常遇到的一個(gè)功能,最近在實(shí)現(xiàn)該功能的時(shí)候遇到一個(gè)問(wèn)題,所以這篇文章主要給大家介紹了關(guān)于mysql分頁(yè)時(shí)offset過(guò)大的Sql優(yōu)化經(jīng)驗(yàn),文中介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面跟著小編來(lái)一起看看吧。
    2017-08-08

最新評(píng)論