order by原理

来源:https://www.cnblogs.com/pzistart/archive/2023/02/05/17093738.html
-Advertisement-
Play Games

一:背景 1. 講故事 上一篇寫完 SQLSERVER 的四個事務隔離級別到底怎麼理解? 之後,有朋友留言問什麼時候可以把 snapshot 隔離級別給補上,這篇就來安排,快照隔離級別看起來很魔法,不過在修車之前,得先看下怎麼開車。 二:snapshot 隔離詳解 1. snapshot 之前的困境 ...


前置知識

Using filesort:表示需要用到 sort buffer 記憶體空間進行排序
sort buffer 是一塊可調整的記憶體空間,如果需要排序的數據量太大而空間不夠,將用到磁碟臨時文件來排序,效率很低

什麼情況下會用到 sort buffer 來排序?

不能根據索引直接知道排序結果,就需要用到 sort buffer

排序的執行情況?

表T:id (primary key), city (key), name, age 等欄位

explain select city,name,age from T where city = 'gz' order by name;
-- 走了索引(但是是非覆蓋索引),需要排序,需要進行回表查詢
-- Using index condition; Using filesort

這個 SQL語句可以知道,不能根據索引直接知道排序結果,所以需用到 sort buffer 排序

● 全欄位排序 執行流程
初始化 sort buffer,確定此記憶體中需要存放的欄位
到 city 欄位索引上找到匹配的第一行
回表查詢,把 city,name,age 存到 sort buffer 中
重覆上述兩步,直到不滿足 where 條件(city 索引上找到一行不滿足的數據)
對 sort buffer 中的數據排序
返回結果集給客戶端

● rowid 排序執行流程
排序前,會檢測放入 sort buffer 中的欄位的長度,如果超過最大單行長度值(可調),那麼就會只放rowid 和 需要排序的欄位

explain select city,name,age from T where city = 'gz' order by name;
-- 走了索引(但是是非覆蓋索引),需要排序,需要進行回表查詢
-- Using index condition; Using filesort

MySQL如果檢測到 city,name,age 等欄位超過了最大單行長度值,就會只把 id, name 等欄位放入 sort buffer 中

執行流程
相比全欄位排序,基本流程一致。存入 sort buffer 中的欄位變少了,在排序完後,又要回表查詢然後返回結果集。效率變低了
這個排序機制是為了保證儘可能的使用 sort buffer 記憶體排序,減少記憶體存放的數據行,那麼存放的數據量就更多。從而降低/不適用磁碟臨時文件排序

如何優化?

可以這樣創建普通索引 (city, name)。那麼執行上述 SQL 語句時,不會用到記憶體排序
執行流程
到 city 欄位索引上找到匹配的第一行
回表查詢,把 city,name,age 作為 結果集 的一部分直接返回
重覆上述兩步,直到不滿足 where 條件


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 註釋 單行註釋:對某一行進行註釋,使用“/註釋內容/”標識 多行註釋:可以書寫多行,使用“/*註釋內容*//”表示 文檔註釋:這個內容對IDEA是有意義的,/**註釋內容*/ public class Hello { //單行註釋 //註釋後會被編譯器忽略,不會作為語句編譯 //每個單行註釋只能寫一 ...
  • 哈嘍兄弟們,今天咱們來學習一下Python字典修改元素的四種方式。 本文中使用的字典對象: smart_girl = {"name":"yuan wai", "age": 25} 第一種方式:[key] smart_girl["age"] = 35 說明:字典中存在key時為修改value、不存在k ...
  • 一、最終效果 遠程開機app下載: 下載鏈接:https://wwp.lanzoup.com/iDR330ml4l2b 提取碼 : dxcg 註意:使用前請按照2.1的步驟設置電腦“ mac地址:填寫自己的mac地址 主機地址:填寫自己的公網ip,百度搜索ip 映射埠:第二點準備工作裡面配置的映射 ...
  • 背景 REST作為一種現代網路應用非常流行的軟體架構風格,自從Roy Fielding博士在2000年他的博士論文中提出來到現在已經有了20年的歷史。它的簡單易用性,可擴展性,伸縮性受到廣大Web開發者的喜愛。 REST 的 API 配合JSON格式的數據交換,使得前後端分離、數據交互變得非常容易, ...
  • 為了方便操作apk 實現app的自動化點擊 封裝了個adb操作類。基本上的操作都有了, 如果配合好C# 程式和模擬器 基本上什麼樣的操作都可以實現。 using System; using System.Collections; using System.Collections.Generic; u ...
  • 在種草了很多天之後,最近終於在淘寶下單了友善 nanoPi R5S。 選擇友善 nanoPi R5S 有兩點主要理由: 1. 自帶 EMMC 存儲,可以使用 RockChip 提供的 MaskRom 模式直接連線燒系統,不依賴 TF 卡(我覺得 TF 卡太累贅了,買普通的又慢又不穩定,對於我這種新手 ...
  • Docker部署SpringBoot項目 前言: 以前幾次在雲伺服器上部署項目都是手動打包,安裝mysql等環境最後再部署運行,相對比較麻煩而且加上網上各種教程質量層次不齊,如果過程中出錯的話排查問題對於新人來說已經夠喝一壺了。(我自己第一次手動裝mysql8.0就出過問題,最後找不到問題所在只能推 ...
  • Git for Windows 的 Bash 有一個很實用的功能,如果當前目錄處於 Git 倉庫中,那麼命令行中會顯示當前 Git 分支的名稱(見下圖)。 然而原版的 MSYS2 Bash 沒有這個功能(見下圖),不過我們可以自己動手配置出相同的效果。 配置方法 打開 MSYS2 的家目錄,找到 . ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...