日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪(fǎng)問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 运维知识 > 数据库 >内容正文

数据库

mysql怎么查看刷脏页慢_一条SQL查询语句极为缓慢,如何去优化呢

發(fā)布時(shí)間:2023/12/3 数据库 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mysql怎么查看刷脏页慢_一条SQL查询语句极为缓慢,如何去优化呢 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

一條 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)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。