中文字幕视频在线看,亚洲精品无码久久久久av老牛,亚洲精品无码av片,亚洲av影院一区二区三区,亚洲国产精品成人久久久

mysql查詢時間范圍內(nèi)的數(shù)據(jù)很慢(mysql數(shù)據(jù)庫速度變慢)

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

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

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

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

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

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

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

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

千萬不要有“把數(shù)據(jù)都查出來,用Java代碼過濾”的想法。

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

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

1、響應(yīng)時間

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

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

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

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

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

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

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

最常用的優(yōu)化方式是為查詢增加一個合適的索引,索引可以讓MySQL以最高效、掃描行數(shù)最少的方式找到需要的記錄。

mysql查詢時間范圍內(nèi)的數(shù)據(jù)很慢(mysql數(shù)據(jù)庫速度變慢)

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

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

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

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

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

版權(quán)聲明:本文內(nèi)容由互聯(lián)網(wǎng)用戶自發(fā)貢獻(xiàn),該文觀點(diǎn)僅代表作者本人。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如發(fā)現(xiàn)本站有涉嫌抄襲侵權(quán)/違法違規(guī)的內(nèi)容, 請發(fā)送郵件至2705686032@qq.com 舉報,一經(jīng)查實(shí),本站將立刻刪除。原文轉(zhuǎn)載: 原文出處:

(0)
尊云-小張的頭像尊云-小張
上一篇 2024 年 5 月 23 日 09:18
下一篇 2024 年 5 月 23 日 09:22

相關(guān)推薦

發(fā)表回復(fù)

登錄后才能評論

聯(lián)系我們

400-900-3935

在線咨詢: QQ交談

郵件:cong@zun.com

工作時間:365天無休服務(wù) 24小時在線

添加微信