mysql怎么查看刷脏页慢_一条SQL查询语句极为缓慢,如何去优化呢
一條 SQL?查詢(xún)語(yǔ)句執(zhí)行的很慢,那是每次查詢(xún)都很慢呢?還是大多數(shù)情況下是正常的,偶爾出現(xiàn)很慢呢?可以分以下兩種情況來(lái)討論。
大多數(shù)情況是正常的,只是偶爾會(huì)出現(xiàn)很慢的情況。
在數(shù)據(jù)量不變的情況下,這條SQL語(yǔ)句一直以來(lái)都執(zhí)行的很慢。
一、平常執(zhí)行快,偶爾很慢
針對(duì)這種情況,可以理解為這條SQL語(yǔ)句的書(shū)寫(xiě)本身是沒(méi)什么問(wèn)題的。而是其他原因?qū)е碌?#xff0c;那會(huì)是什么原因呢?
(1)? 數(shù)據(jù)庫(kù)在刷新臟頁(yè)(flush)
要往數(shù)據(jù)庫(kù)中插入、更新一條數(shù)據(jù)時(shí),數(shù)據(jù)庫(kù)會(huì)先在內(nèi)存中將這一條數(shù)據(jù)更新,但卻不會(huì)立即持久化到磁盤(pán)中,而是把這些記錄寫(xiě)入到redo log中,等到空閑的時(shí)候,再?gòu)膔edo log中把數(shù)據(jù)同步到磁盤(pán)中去。
當(dāng)內(nèi)存數(shù)據(jù)頁(yè)跟磁盤(pán)數(shù)據(jù)頁(yè)內(nèi)容不一致的時(shí)候,我們稱(chēng)這個(gè)內(nèi)存頁(yè)為“臟頁(yè)”。內(nèi)存數(shù)據(jù)寫(xiě)入到磁盤(pán)后,內(nèi)存和磁盤(pán)上的數(shù)據(jù)頁(yè)的內(nèi)容就一致了,稱(chēng)為“干凈頁(yè)”。
redo寫(xiě)滿(mǎn)了:redo log的容量是有限的,當(dāng)數(shù)據(jù)庫(kù)一直很忙,更新又比較頻繁,此時(shí)redo log很快被寫(xiě)滿(mǎn),數(shù)據(jù)庫(kù)就只能先暫停其他操作,全身心將數(shù)據(jù)同步到磁盤(pán)中去,所以說(shuō),數(shù)據(jù)庫(kù)在在同步數(shù)據(jù)到磁盤(pán)的時(shí)候,就有可能導(dǎo)致我們的SQL語(yǔ)句執(zhí)行的很慢了。
內(nèi)存不夠了:另外,當(dāng)一次性查詢(xún)的數(shù)據(jù)太多,又恰好碰到所查詢(xún)的數(shù)據(jù)也不在內(nèi)存中,需要申請(qǐng)內(nèi)存,而此時(shí)恰好內(nèi)存不足,就需要淘汰一部分內(nèi)存數(shù)據(jù)頁(yè),如果是干凈頁(yè),就直接釋放,如果是臟頁(yè),就需要刷新。
(2)? 拿不到鎖
當(dāng)我們要執(zhí)行的這條語(yǔ)句,它涉及到的表或行,剛好別人在用,且加了鎖,那我們拿不到鎖就只能慢慢等別人釋放鎖了。
如果要判斷是否真的在等待鎖,我們可以用? show processlist? 這個(gè)命令來(lái)查看當(dāng)前的狀態(tài)。
二、一直都很慢
如果在同一數(shù)據(jù)量的情況下,其他SQL語(yǔ)句執(zhí)行速度都很快,唯獨(dú)這條 SQL 語(yǔ)句每次都執(zhí)行的這么慢,那就就要好好反思一下你的 SQL?語(yǔ)句了
(1)? 沒(méi)有用到索引
這種情況又要細(xì)分:
a、字段沒(méi)有建索引
b、字段有索引,但是沒(méi)有用上
比如說(shuō)select * from table_A a where a.no+1=100? ? ( 就算在no列建立了索引,但是對(duì)左邊做了運(yùn)算,會(huì)導(dǎo)致索引失效 )
c、 函數(shù)操作導(dǎo)致索引失效
比如說(shuō)一個(gè)字段name,你對(duì)它用了str()或一些其他函數(shù),也會(huì)導(dǎo)致索引失效
(2)? 數(shù)據(jù)庫(kù)選錯(cuò)索引
就算某個(gè)字段例如name建立了索引,但系統(tǒng)也會(huì)去評(píng)估按照索引搜索快還是全表掃描快,而它判斷的依據(jù)是什么呢?采用取樣的方式,來(lái)估計(jì)數(shù)據(jù)量,所以,如果樣品數(shù)據(jù)不能代表整體數(shù)據(jù),就會(huì)導(dǎo)致偏差,數(shù)據(jù)庫(kù)就會(huì)誤判。
這種情況下可以強(qiáng)制使用索引,例如 select * from table_A a force index(ind) where 10< a.no and a.no<10000;
三、總結(jié)
一個(gè) SQL 執(zhí)行的很慢,我們要分兩種情況討論:
1、平常執(zhí)行快,偶爾很慢,則有如下原因
a、數(shù)據(jù)庫(kù)在刷新臟頁(yè),例如 redo log 寫(xiě)滿(mǎn)了需要同步到磁盤(pán)。
b、執(zhí)行的時(shí)候,遇到鎖,如表鎖、行鎖。
2、一直都很慢,則有如下原因。
a、沒(méi)有用上索引:例如該字段沒(méi)有索引;由于對(duì)字段進(jìn)行運(yùn)算、函數(shù)操作導(dǎo)致無(wú)法用索引。
b、數(shù)據(jù)庫(kù)選錯(cuò)了索引。
總結(jié)
以上是生活随笔為你收集整理的mysql怎么查看刷脏页慢_一条SQL查询语句极为缓慢,如何去优化呢的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: linux自动补全命令(linux 自动
- 下一篇: centos 7 mysql随机密码_在