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

MySQL慢查詢以及重構(gòu)查詢的方式記錄

 更新時間:2021年06月16日 11:55:29   作者:臨時營地  
MySQL的慢查詢,全名是慢查詢?nèi)罩?是MySQL提供的一種日志記錄,用來記錄在MySQL中響應(yīng)時間超過閥值的語句,這篇文章主要給大家介紹了關(guān)于MySQL慢查詢以及重構(gòu)查詢的相關(guān)資料,需要的朋友可以參考下

前言

什么是慢查詢,如何優(yōu)化慢查詢,下面介紹這兩個知識點(diǎn)的相關(guān)知識。

慢查詢基礎(chǔ):優(yōu)化數(shù)據(jù)訪問

是否向數(shù)據(jù)庫請求了不需要的數(shù)據(jù)

查詢不需要的記錄:解決方案:查詢后面加上Limit

多表關(guān)聯(lián)時返回全部列:解決方案:只取需要的列

總是取出全部列:select * 解決方案:最好還是獲取部分列,除非應(yīng)用程序處緩存列的數(shù)據(jù)了

重復(fù)查詢相同的數(shù)據(jù):解決方案:需要時從緩存中取出

MySQL是否在掃描額外的記錄

可以從響應(yīng)時間,掃描的行數(shù),返回的行數(shù)來進(jìn)行查詢開銷的衡量。

要想減少掃描行數(shù)可以使用索引對需要的記錄進(jìn)行覆蓋,但是增加索引不意味著就能讓掃描的行數(shù)等于返回的行數(shù),比如sum,count之類的聚合函數(shù)

重構(gòu)查詢的方法

一個復(fù)雜查詢還是多個簡單查詢

在過去,總是強(qiáng)調(diào)需要數(shù)據(jù)庫層完成盡可能多的工作,因?yàn)檫^去網(wǎng)絡(luò)通信查詢解析和優(yōu)化是一件代價很高的事情。

但是這樣的想法對于MySQL并不適用,MySQL從設(shè)計(jì)上讓連接和斷開連接都很輕量級,在返回一個小的查詢結(jié)果方面很高效?,F(xiàn)代的網(wǎng)絡(luò)速度比以前要快很多,無論是帶寬還是延遲。在某些版本的MySQL上,即使在一個通用服務(wù)器上,也能夠運(yùn)行每秒超過10萬的查詢,即使是一個千兆網(wǎng)卡也能輕松滿足每秒超過2000次的查詢。所以運(yùn)行多個小查詢現(xiàn)在已經(jīng)不是大問題了。

當(dāng)然,相比較于內(nèi)部掃描,響應(yīng)數(shù)據(jù)給客戶端更加耗時,所以在同條件下,使用盡可能少的查詢更好。

切分查詢

當(dāng)使用sql進(jìn)行查詢時,需要注意將大查詢切分成小查詢,可以減少對數(shù)據(jù)庫的影響,因?yàn)橐粋€大語句一次性完成的話,則可能一次鎖住很多數(shù)據(jù),占滿整個事務(wù)日志,耗盡系統(tǒng)資源,阻塞其他查詢。

比如我們做數(shù)據(jù)統(tǒng)計(jì)時要對大量訂單號的信息進(jìn)行查詢,那么是一次性用in查詢,還是切割參數(shù)list多次查詢呢,答案是切割參數(shù)list多次查詢,因?yàn)楫?dāng)in里面的參數(shù)過多時,MySQL就會認(rèn)為再走索引已經(jīng)不行了,可能就會進(jìn)行全表查詢,如果這個時候數(shù)據(jù)表數(shù)據(jù)量過大,那可能就會造成查詢超時。

// chops a list into non-view sublists of length L
static <T> List<List<T>> chopped(List<T> list, final int L) {
    List<List<T>> parts = new ArrayList<List<T>>();
    final int N = list.size();
    for (int i = 0; i < N; i += L) {
        parts.add(new ArrayList<T>(
            list.subList(i, Math.min(N, i + L)))
        );
    }
    return parts;
}
List<Integer> numbers = Collections.unmodifiableList(
    Arrays.asList(5,3,1,2,9,5,0,7)
);
List<List<Integer>> parts = chopped(numbers, 3);
System.out.println(parts); // prints "[[5, 3, 1], [2, 9, 5], [0, 7]]"
parts.get(0).add(-1);
System.out.println(parts); // prints "[[5, 3, 1, -1], [2, 9, 5], [0, 7]]"
System.out.println(numbers); // prints "[5, 3, 1, 2, 9, 5, 0, 7]" (unmodified!)

在程序中將list截?cái)?,從而使查詢能使用索引而不是進(jìn)行全表掃描。

阿里開發(fā)手冊中就推薦仔細(xì)評估in后面的集合元素?cái)?shù)量,控制在1000個之內(nèi)。

分解關(guān)聯(lián)查詢

將多表inner join 進(jìn)行分解,分解成小查詢,超過三個表的join,就需要禁止了。

優(yōu)點(diǎn)有:

  1. 緩存的效率會更高,
  2. 分解后的查詢可以減少鎖的競爭
  3. 應(yīng)用層可以緩存查詢數(shù)據(jù),減小數(shù)據(jù)庫的壓力。
  4. 可以提升查詢效率,因?yàn)橛弥麈I之類進(jìn)行in查詢,比按照條件范圍查詢可能會更高效,尤其是大表的時候。
  5. 可以減少冗余記錄的查詢
  6. 更進(jìn)一步,這樣做相當(dāng)于在應(yīng)用中實(shí)現(xiàn)了哈希關(guān)聯(lián),而不是使用MySQL的嵌套循環(huán)關(guān)聯(lián)。某些場景哈希關(guān)聯(lián)的效率要高很多。

總結(jié)

到此這篇關(guān)于MySQL慢查詢以及重構(gòu)查詢的文章就介紹到這了,更多相關(guān)MySQL慢查詢重構(gòu)查詢內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MySQL中無過濾條件的count詳解

    MySQL中無過濾條件的count詳解

    這篇文章主要給大家介紹了關(guān)于MySQL中無過濾條件count的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起看看吧
    2019-02-02
  • mysql服務(wù)無法啟動報(bào)錯誤1067解決方法(mysql啟動錯誤1067	)

    mysql服務(wù)無法啟動報(bào)錯誤1067解決方法(mysql啟動錯誤1067 )

    mysql服務(wù)無法啟動報(bào)錯誤1067解決方法,大家參考使用吧
    2013-12-12
  • MySql5.5忘記root密碼怎么辦

    MySql5.5忘記root密碼怎么辦

    使用mysql5.5,突然root密碼忘記,怎么也登錄不了,很急人,該怎么解決呢?下面通過本文給大家介紹mysql5.5忘記root密碼的解決辦法,需要的朋友參考下吧
    2016-01-01
  • 關(guān)于mysql數(shù)據(jù)庫格式化簡單介紹

    關(guān)于mysql數(shù)據(jù)庫格式化簡單介紹

    本文將介紹關(guān)于mysql數(shù)據(jù)庫格式化時需要注意的一些問題,需要的朋友可以參考下
    2012-11-11
  • Mac下忘記mysql密碼重新設(shè)置密碼的圖文教程

    Mac下忘記mysql密碼重新設(shè)置密碼的圖文教程

    這篇文章主要介紹了Mac下忘記mysql密碼重新設(shè)置密碼的教程,非常不錯具有參考借鑒價值,需要的朋友可以參考下
    2016-12-12
  • 一文弄懂MySQL中redo?log與binlog的區(qū)別

    一文弄懂MySQL中redo?log與binlog的區(qū)別

    在學(xué)習(xí)mysql數(shù)據(jù)庫時,不可避免要去接觸到redo log和binlog,好多人對這兩者的概念分不太清,下面這篇文章主要給大家介紹了關(guān)于MySQL中redo?log與binlog區(qū)別的相關(guān)資料,需要的朋友可以參考下
    2022-02-02
  • MySQL中將逗號分隔的字段轉(zhuǎn)換為多行數(shù)據(jù)的方法

    MySQL中將逗號分隔的字段轉(zhuǎn)換為多行數(shù)據(jù)的方法

    在我們的實(shí)際開發(fā)中,經(jīng)常需要存儲一些字段,它們使用像,?-?等連接符進(jìn)行連接,在查詢過程中,有時需要將這些字段使用連接符分割,然后查詢多條數(shù)據(jù),今天,我們將使用一個實(shí)際的生產(chǎn)場景來詳細(xì)解釋這個解決方案,需要的朋友可以參考下
    2024-04-04
  • MySQL數(shù)據(jù)庫事務(wù)隔離級別詳解

    MySQL數(shù)據(jù)庫事務(wù)隔離級別詳解

    這篇文章主要介紹了MySQL數(shù)據(jù)庫事務(wù)隔離級別詳解的相關(guān)資料,需要的朋友可以參考下
    2017-03-03
  • 清空mysql 查詢緩存的可行方法

    清空mysql 查詢緩存的可行方法

    mysql對同一條sql進(jìn)行了緩存,在第二次運(yùn)行時, 瞬間就完成了,若要清除緩存,可通過下面的方法來實(shí)現(xiàn)
    2014-07-07
  • Mysql百萬級分頁優(yōu)化技巧

    Mysql百萬級分頁優(yōu)化技巧

    這篇文章主要介紹了Mysql百萬級分頁優(yōu)化技巧,包括普通分頁和優(yōu)化分頁兩種,在數(shù)據(jù)量比較大的時候,我們盡量去利用索引來優(yōu)化語句。下面通過本文給大家詳細(xì)講解,一起看看吧
    2016-12-12

最新評論