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

為什么MySQL查詢速度會(huì)慢

 更新時(shí)間:2022年12月01日 08:19:57   作者:哪吒編程  
這篇文章主要介紹了為什么MySQL查詢速度會(huì)慢的相關(guān)資料,需要的朋友可以參考下

一、先了解一下MySQL查詢的執(zhí)行過(guò)程

MySQL在查詢時(shí),它是由很多子任務(wù)組成的,每個(gè)子任務(wù)都會(huì)消耗一定的時(shí)間,如果要想優(yōu)化查詢,實(shí)際上要優(yōu)化其子任務(wù),可以消除一些子任務(wù)、減少子任務(wù)的執(zhí)行次數(shù)、讓子任務(wù)執(zhí)行的更快。

MySQL查詢的執(zhí)行過(guò)程:從客戶端到服務(wù)器、然后在服務(wù)器進(jìn)行解析、生成執(zhí)行計(jì)劃、執(zhí)行、返回結(jié)果給客戶端。

執(zhí)行是最重要的階段,包括調(diào)用存儲(chǔ)引擎檢索數(shù)據(jù)、調(diào)用后的數(shù)據(jù)處理、排序、分組等;

查詢需要在不同的地方花費(fèi)時(shí)間,包括網(wǎng)絡(luò)、CPU計(jì)算、生成統(tǒng)計(jì)信息、生成執(zhí)行計(jì)劃、鎖等待等,尤其是向底層存儲(chǔ)引擎檢索數(shù)據(jù)的調(diào)用操作,這些調(diào)用需要在內(nèi)存操作、CPU操作和內(nèi)存不足時(shí)導(dǎo)致的IO操作上花費(fèi)時(shí)間。根據(jù)存儲(chǔ)引擎不同,可能還會(huì)產(chǎn)生大量的上下文切換以及系統(tǒng)調(diào)用。

不必要的額外操作、不必要的重復(fù)操作、某些操作執(zhí)行的太慢都是查詢慢的原因,優(yōu)化查詢的目的就是減少和消除這些操作所花費(fèi)的時(shí)間。

二、是否查詢了不需要的數(shù)據(jù)

有些查詢會(huì)查詢很多不需要的數(shù)據(jù),查詢之后,程序中并未使用,這樣不但會(huì)給MySQL服務(wù)器帶來(lái)額外的負(fù)擔(dān),還會(huì)增加網(wǎng)絡(luò)開銷,也會(huì)消耗應(yīng)用服務(wù)器的CPU和內(nèi)存資源,簡(jiǎn)而言之,吃多少拿多少。

千萬(wàn)不要有“把數(shù)據(jù)都查出來(lái),用Java代碼過(guò)濾”的想法。

禁止使用select *進(jìn)行查詢。

三、衡量查詢開銷的幾個(gè)重要指標(biāo)

1、響應(yīng)時(shí)間

響應(yīng)時(shí)間可以分為服務(wù)時(shí)間和排序時(shí)間。

  • 服務(wù)時(shí)間指數(shù)據(jù)庫(kù)處理這個(gè)查詢真正花費(fèi)的時(shí)間;
  • 排隊(duì)時(shí)間指服務(wù)器因?yàn)榈却承┵Y源而沒(méi)有真正執(zhí)行查詢的時(shí)間,比如等待IO操作、等待行鎖。

2、掃描的行數(shù)和返回的行數(shù)

較短的行的訪問(wèn)速度更快,內(nèi)存中的行比磁盤中的行的訪問(wèn)速度要快得多。

理想情況下掃描的行數(shù)和返回的行數(shù)是相同的。但這種情況并不多見,比如關(guān)聯(lián)查詢的時(shí)候,服務(wù)器必須掃描更多的行才能得到結(jié)果,因此,越多的表關(guān)聯(lián),性能越低。

3、掃描的行數(shù)和訪問(wèn)類型

MySQL可以通過(guò)多種方式查詢并返回結(jié)果集,速度從慢到快,掃描的行數(shù)由多到少,依次為全表掃描、索引掃描、范圍掃描、唯一索引掃描、常數(shù)引用。

最常用的優(yōu)化方式是為查詢?cè)黾右粋€(gè)合適的索引,索引可以讓MySQL以最高效、掃描行數(shù)最少的方式找到需要的記錄。

4、一般可以通過(guò)explain的Extra列查看查詢的優(yōu)劣

一般MySQL能夠使用以下三種方式應(yīng)用where條件,從好到壞依次為:

  • 在索引中使用where條件過(guò)濾不匹配的記錄,這是在存儲(chǔ)引擎層完成的;
  • 使用索引覆蓋掃描,也就是Extra中出現(xiàn)Using index,直接從索引中過(guò)濾不需要的記錄并返回命中的結(jié)果,這是在MySQL服務(wù)器層完成的,無(wú)須再回表查詢記錄;
  • Extra中出現(xiàn)Using where,這是在MySQL服務(wù)器層完成的,MySQL需要先從數(shù)據(jù)表讀取記錄,然后過(guò)濾。

Extra中出現(xiàn)Using where時(shí),可以通過(guò)如下方式優(yōu)化:

  • 使用索引覆蓋掃描,把所有需要的列都放到索引中,這樣就不用回表查詢了;
  • 改變表結(jié)構(gòu),比如使用匯總表;
  • 重寫sql,讓MySQL優(yōu)化器能夠以更優(yōu)化的方式執(zhí)行這個(gè)sql;

到此這篇關(guān)于為什么MySQL查詢速度會(huì)慢的文章就介紹到這了,更多相關(guān)MySQL查詢速度慢內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 關(guān)于MySQL中datetime和timestamp的區(qū)別解析

    關(guān)于MySQL中datetime和timestamp的區(qū)別解析

    在MySQL中一些日期字段的類型選擇為datetime和timestamp,那么對(duì)于這兩種類型不同的應(yīng)用場(chǎng)景是什么呢,這篇文章主要介紹了關(guān)于MySQL中datetime和timestamp的區(qū)別解析,需要的朋友可以參考下
    2023-06-06
  • win10 mysql導(dǎo)出csv的兩種方式

    win10 mysql導(dǎo)出csv的兩種方式

    win10導(dǎo)出csv有兩種方式,第一種是借助工具,第二種是原始SQL語(yǔ)句導(dǎo)出,這篇文章主要介紹了win10 mysql導(dǎo)出csv的兩種方式,需要的朋友可以參考下
    2019-12-12
  • MySQL UPDATE 語(yǔ)句的非標(biāo)準(zhǔn)實(shí)現(xiàn)代碼

    MySQL UPDATE 語(yǔ)句的非標(biāo)準(zhǔn)實(shí)現(xiàn)代碼

    這篇文章主要介紹了MySQL UPDATE 語(yǔ)句的非標(biāo)準(zhǔn)實(shí)現(xiàn)代碼,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-04-04
  • MySQL中的各種查詢問(wèn)題

    MySQL中的各種查詢問(wèn)題

    這篇文章主要介紹了MySQL中的各種查詢問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • MYSQL隨機(jī)抽取查詢 MySQL Order By Rand()效率問(wèn)題

    MYSQL隨機(jī)抽取查詢 MySQL Order By Rand()效率問(wèn)題

    MYSQL隨機(jī)抽取查詢:MySQL Order By Rand()效率問(wèn)題一直是開發(fā)人員的常見問(wèn)題,俺們不是DBA,沒(méi)有那么牛B,所只能慢慢研究咯,最近由于項(xiàng)目問(wèn)題,需要大概研究了一下MYSQL的隨機(jī)抽取實(shí)現(xiàn)方法
    2011-11-11
  • MySQL Innodb關(guān)鍵特性之插入緩沖(insert buffer)

    MySQL Innodb關(guān)鍵特性之插入緩沖(insert buffer)

    這篇文章主要介紹了MySQL Innodb關(guān)鍵特性之插入緩沖的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用Innodb存儲(chǔ)引擎,感興趣的朋友可以了解下
    2021-04-04
  • MySQL中的長(zhǎng)事務(wù)示例詳解

    MySQL中的長(zhǎng)事務(wù)示例詳解

    這篇文章主要給大家介紹了關(guān)于MySQL中長(zhǎng)事務(wù)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用MySQL具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • mysql 中存在null和空時(shí)創(chuàng)建唯一索引的方法

    mysql 中存在null和空時(shí)創(chuàng)建唯一索引的方法

    據(jù)庫(kù)默認(rèn)值都有null,此時(shí)創(chuàng)建唯一索引時(shí)要注意了,此時(shí)數(shù)據(jù)庫(kù)會(huì)把空作為多個(gè)重復(fù)值
    2014-10-10
  • MySQL 5.6下table_open_cache參數(shù)優(yōu)化合理配置詳解

    MySQL 5.6下table_open_cache參數(shù)優(yōu)化合理配置詳解

    這篇文章主要介紹了MySQL 5.6下table_open_cache參數(shù)合理配置詳解,需要的朋友可以參考下
    2018-03-03
  • mysql 5.5 安裝配置方法圖文教程

    mysql 5.5 安裝配置方法圖文教程

    這篇文章主要為大家分享了mysql 5.5安裝配置方法圖文教程,感興趣的朋友可以參考一下
    2016-11-11

最新評(píng)論