91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MySQL中怎么實現排序

發布時間:2021-07-13 16:10:25 來源:億速云 閱讀:182 作者:Leah 欄目:數據庫

這期內容當中小編將會給大家帶來有關MySQL中怎么實現排序,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

MySQL中怎么實現排序

在我們執行Mysql的Explain語句的時候,經常會看到這樣的一個Using  filesort。那么,Mysql的排序是在內存里面進行的,還是在磁盤里面進行的呢?假如我們是Mysql的設計者,我們會怎么做呢?首先,在內存里面來進行排序的速度,肯定是遠遠大于在磁盤中的。但是內存的資源畢竟有限,假如我們掃描到足夠多的行,這個時候可能數據的大小已經超過內存,想在內存中進行排序是很困難的,這個時候我們只能夠使用磁盤來進行排序了。

沒錯,Mysql也是這么設計的,Mysql有一個配置項,sort_buffer_size,如果我們Select到的數據量小于這個數,那么就會將數據在內存中進行排序,否則,Mysql就會把數據拆成很多個臨時文件,每個臨時文件的大小都會小于sort_buffer_size。也就是說,如果sort_buffer_size越小,拆分的臨時文件就會越多,這也是為什么我們選來當存儲的機器內存也要盡量大的原因。Mysql排序了多個臨時文件之后,最后在做一次歸并排序,就可以將所有記錄排完了。

相信大家下面這樣的話,如果你的數據庫的列數比較多,那么盡量地不要使用Select *  而是需要什么字段就只取什么字段,在數據庫的排序中尤為如此。假如我們的數據列數特別多,滿足條件的行數也多,這個時候,Mysql就不得不用更極端的排序算法進行排序,每一行數據,都只取主鍵id跟排序的字段。然后進行排序,最后,再取要滿足條件的結果回表查詢其他字段,然后返回結果。相對于原有上面的方案,這種Rowid的排序方式多了一次回表,所以查詢效率大打折扣。

那么,我們有什么辦法可以進行排序的優化呢?我們都知道,Innodb的索引實際上是一顆多叉排序樹,那么假如我們能夠在已有的排序樹上取得結果,豈不美哉?!所以,如果我們要查詢已經要排序的字段全都在已有的索引上,并且滿足最左前綴原則,那么,我們就可以減少一次回表,從而大大提升效率。那么,如果判斷你的Sql語句滿足了這種優化呢?如果你的語句中含有OrderBy,但是Explain的結果卻只有UseIndex,說明命中了索引覆蓋。

上述就是小編為大家分享的MySQL中怎么實現排序了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

宁都县| 新干县| 孟州市| 景泰县| 温州市| 淮安市| 宁波市| 邢台市| 宝坻区| 始兴县| 任丘市| 上林县| 河津市| 祥云县| 高邮市| 喀什市| 崇义县| 泸水县| 大化| 怀宁县| 天柱县| 迁安市| 昌邑市| 浑源县| 台南县| 比如县| 临泽县| 大渡口区| 岗巴县| 富源县| 西和县| 井陉县| 勐海县| 龙门县| 浮梁县| 翼城县| 白河县| 禹城市| 巴马| 内黄县| 唐海县|