本篇內(nèi)容介紹了“MySQL中filesort指的是什么”的有關(guān)知識(shí),在實(shí)際案例的操作過程中,不少人都會(huì)遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!
讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對(duì)這個(gè)行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡(jiǎn)單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價(jià)值的長期合作伙伴,公司提供的服務(wù)項(xiàng)目有:域名申請(qǐng)、網(wǎng)絡(luò)空間、營銷軟件、網(wǎng)站建設(shè)、宜都網(wǎng)站維護(hù)、網(wǎng)站推廣。
在mysql中,filesort是指文件排序,是通過相應(yīng)的排序算法,將取得的數(shù)據(jù)在內(nèi)存中進(jìn)行排序。filesort分兩種:1、雙路排序,是首先根據(jù)相應(yīng)的條件取出相應(yīng)的排序字段和可以直接定位行數(shù)據(jù)的行指針信息,然后在sort buffer 中進(jìn)行排序;2、單路排序,是一次性取出滿足條件行的所有字段,然后在sort buffer中進(jìn)行排序。
在MySQL中的ORDER BY有兩種排序?qū)崿F(xiàn)方式:
1. 利用有序索引獲取有序數(shù)據(jù)
2. 文件排序(filesort)
在explain中分析查詢的時(shí)候,利用有序索引獲取有序數(shù)據(jù)顯示Using index ,文件排序顯示 Using filesort。
只有當(dāng)ORDER BY中所有的列必須包含在相同的索引,并且索引的順序和order by子句中的順序完全一致,并且所有列的排序方向(升序或者降序)一樣才有,(混合使用ASC模式和DESC模式則不使用索引)
where語句 與 order by 語句組合滿足最左前綴
在其他的情況下 使用 文件排序如下:
1) where語句與order by語句,使用了不同的索引
??2) 檢查的行數(shù)過多,且沒有使用覆蓋索引
??3) ORDER BY中的列不包含在相同的索引,也就是使用了不同的索引
??4) 對(duì)索引列同時(shí)使用了ASC和DESC
??5) where語句或者ORDER BY語句中索引列使用了表達(dá)式,包括函數(shù)表達(dá)式
??6) where 語句與ORDER BY語句組合滿足最左前綴,但where語句中查找的是范圍。
這個(gè) filesort 并不是說通過磁盤文件進(jìn)行排序,而只是告訴我們進(jìn)行了一個(gè)排序操作。即在MySQL Query Optimizer 所給出的執(zhí)行計(jì)劃(通過 EXPLAIN 命令查看)中被稱為文件排序(filesort)
??文件排序是通過相應(yīng)的排序算法,將取得的數(shù)據(jù)在內(nèi)存中進(jìn)行排序: MySQL需要將數(shù)據(jù)在內(nèi)存中進(jìn)行排序,所使用的內(nèi)存區(qū)域也就是我們通過sort_buffer_size 系統(tǒng)變量所設(shè)置的排序區(qū)。這個(gè)排序區(qū)是每個(gè)Thread 獨(dú)享的,所以說可能在同一時(shí)刻在MySQL 中可能存在多個(gè) sort buffer 內(nèi)存區(qū)域。
filesort分兩種
雙路排序:是首先根據(jù)相應(yīng)的條件取出相應(yīng)的排序字段和可以直接定位行數(shù)據(jù)的行指針信息,然后在sort buffer 中進(jìn)行排序。排序后再吧查詢字段依照行指針取出,共執(zhí)行兩次磁盤io。
單路排序:是一次性取出滿足條件行的所有字段,然后在sort buffer中進(jìn)行排序。 執(zhí)行一次磁盤io。
MySQL主要通過比較我們所設(shè)定的系統(tǒng)參數(shù) max_length_for_sort_data的大小和Query 語句所取出的字段類型大小總和來判定需要使用哪一種排序算法。如果 max_length_for_sort_data更大,則使用第二種優(yōu)化后的算法,反之使用第一種算法。所以如果希望 ORDER BY 操作的效率盡可能的高,一定要主義max_length_for_sort_data 參數(shù)的設(shè)置。曾經(jīng)就有同事的數(shù)據(jù)庫出現(xiàn)大量的排序等待,造成系統(tǒng)負(fù)載很高,而且響應(yīng)時(shí)間變得很長,最后查出正是因?yàn)镸ySQL 使用了傳統(tǒng)的第一種排序算法而導(dǎo)致,在加大了max_length_for_sort_data 參數(shù)值之后,系統(tǒng)負(fù)載馬上得到了大的緩解,響應(yīng)也快了很多。
如果order by的子句只引用了聯(lián)接中的第一個(gè)表,MySQL會(huì)先對(duì)第一個(gè)表進(jìn)行排序,然后進(jìn)行聯(lián)接。也就是expain中的Extra的Using Filesort.否則MySQL先把結(jié)果保存到臨時(shí)表(Temporary Table),然后再對(duì)臨時(shí)表的數(shù)據(jù)進(jìn)行排序.此時(shí)expain中的Extra的顯示Using temporary Using Filesort.
“mysql中filesort指的是什么”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!