MySQL是如何選擇索引的?

2.3.5. 索引選擇

MySQL是如何選擇索引的?

優化器決定了具體某一索引的選擇,也就是常說的執行計劃。而優化器的選擇是基于成本(cost),哪個索引的成本越低,優先使用哪個索引。

SQL 優化器會分析所有可能的執行計劃,選擇成本最低的執行,這種優化器稱之為:CBO(Cost-based Optimizer,基于成本的優化器)。

Cost  = Server Cost + Engine Cost= CPU Cost + IO Cost

CPU Cost 表示計算的開銷,比如索引鍵值的比較、記錄值的比較、結果集的排序……這些操作都在 Server 層完成;

IO Cost 表示引擎層 IO 的開銷,MySQL 8.0 可以通過區分一張表的數據是否在內存中,分別計算讀取內存 IO 開銷以及讀取磁盤 IO 的開銷。

優化器認為一條 SQL 需要創建基于磁盤的臨時表,這時的成本是最大的,索引鍵值的比較、記錄之間的比較,其實開銷是非常低的,但如果要比較的記錄數非常多,則成本會變得非常大。

MySQL索引出錯案例分析

索引創建在有限狀態上:

B+ 樹索引通常要建立在高選擇性的字段或字段組合上,如性別、訂單 ID、日期等,因為這樣每個字段值大多并不相同。像性別這種字段只有男女兩種,是低選擇性的字段,因此無須在性別字段上創建索引。

在有些低選擇性的列上,是有必要創建索引的。比如電商的核心業務表。

在電商業務中會有一個這樣的邏輯:會定期掃描支付狀態為支付中的訂單,然后強制讓其關閉,從而釋放庫存,給其他有需求的買家進行購買。一般僅為已完成、支付中、超時已關閉這幾種。絕大部分都是已完成,只有絕少部分因為系統故障原因,會在 15 分鐘后還沒有完成訂單,因此訂單狀態是存在數據傾斜的。

例如支付狀態只有已完成、支付中、超時已關閉三種,有一百萬條數據,優化器會認為每個狀態占用三分之一數據,使用全表掃描,避免二級索引回表效率會更高。

然而,由于數據傾斜,訂單狀態為支付中的數據非常少(例如有1萬條),這時根據索引的查詢效率會更高。

這時可以利用 MySQL 8.0 的直方圖功能,創建一個直方圖,讓優化器知道數據的分布,從而更好地選擇執行計劃。

建立索引時要注意的事:

  • 經常頻繁用作查詢條件的字段應酌情考慮為其創建索引。
  • 表的主外鍵或連表字段,必須建立索引,因為能很大程度提升連表查詢的性能。
  • 建立索引的字段,一般值的區分性要足夠高,這樣才能提高索引的檢索效率。
  • 建立索引的字段,值不應該過長,如果較長的字段要建立索引,可以選擇前綴索引。
  • 建立聯合索引,應當遵循最左前綴原則,將多個字段之間按優先級順序組合。
  • 經常根據范圍取值、排序、分組的字段應建立索引,因為索引有序,能加快排序時間。
  • 對于唯一索引,如果確認不會利用該字段排序,那可以將結構改為Hash結構。
  • 盡量使用聯合索引代替單值索引,聯合索引比多個單值索引查詢效率要高。

同時,還需有些注意點:

  • 值經常會增刪改的字段,不合適建立索引,因為每次改變后需維護索引結構。
  • 一個字段存在大量的重復值時,不適合建立索引,比如之前舉例的性別字段。
  • 索引不能參與計算,因此經常帶函數查詢的字段,并不適合建立索引。
  • 建立聯合索引時,一定要考慮優先級,查詢頻率最高的字段應當放首位。
  • 當表的數據較少,不應當建立索引,因為數據量不大時,維護索引反而開銷更大。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/12733.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/12733.shtml
英文地址,請注明出處:http://en.pswp.cn/web/12733.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Python操作鼠標鍵盤和爬蟲

一.pyautogui 庫 pyautogui 是一個 Python 庫,允許控制鼠標和鍵盤。可以通過它編寫 Python 腳本來自動執行各種任務,例如點擊按鈕、輸入文本、移動鼠標等。這個庫非常適合用來編寫自動化腳本來完成重復性的工作,比如網頁表單填寫、屏幕截圖、…

STC8增強型單片機開發——定時器Timer

一、定時器 定時器是一種計時裝置,通常由一個晶體振蕩器提供時鐘信號,可以計時一定的時間后執行相應的操作。在單片機中,定時器一般是由計數器和時鐘源組成的,可以用來產生一定時間間隔的中斷信號,或者用于測量輸入信號…

開放式運動耳機哪款好用?五款高性能值得信賴產品推薦

身為戶外運動的達人,我發現開放式運動耳機簡直是咱們運動時的最佳拍檔,不管是跑步還是健身,開放式運動耳機最為舒適,它的妙處就在于不用塞進耳朵,這樣既安全又衛生,戶外動起來更放心。但市面上好壞參半&…

AIGC行業:探索發展風口,把握市場脈搏

AIGC行業現在適合進入嗎 簡介: AIGC行業:探索發展風口,把握市場脈搏 隨著人工智能技術的快速發展,AIGC(人工智能生成內容)行業正逐漸成為科技界的新寵。在當前的時代背景下,我們不禁要問&…

Chisel中對對<: 和:的理解(其實是Scala中的理解)

在 Scala 語言和 Chisel 硬件構造語言中&#xff0c;<: 和 : 是用于類型注解的兩個不同的符號&#xff0c;它們在泛型編程和類型系統中扮演重要角色。下面是它們各自的意義和用途&#xff1a; <:&#xff08;子類型關系&#xff09; <: 符號在 Scala 中表示子類型關…

Nginx詳細介紹一

Nginx是一個高性能的HTTP和反向代理服務器&#xff0c;它也可以作為郵件服務器使用。 Nginx基本介紹 基本概念&#xff1a; Nginx可以處理大量的并發連接&#xff0c;具有很高的穩定性和低資源消耗的特點。它主要用于Web服務、反向代理、負載均衡和HTTP緩存等場景。 安裝與配…

【半夜學習MySQL】內置函數(含日期、字符串、數學等函數常用用法介紹及示例詳解)

&#x1f3e0;關于專欄&#xff1a;半夜學習MySQL專欄用于記錄MySQL數據相關內容。 &#x1f3af;每天努力一點點&#xff0c;技術變化看得見 文章目錄 日期函數字符串函數數學函數其他函數 日期函數 函數名稱描述current_date()當前日期current_time()當前時間current_time()…

php8.2使用laravel V11.0

報錯&#xff1a;You must enable the openssl extension in your php.ini to load information from https://mirrors.aliyun.com/composer 1、搜索&#xff1a;extension_dir去掉;號 2、搜索&#xff1a;extensionopenssl去掉;號

幻獸帕魯Palworld服務器手動部署

目錄 帕魯官方文檔手動安裝steamcmd通過steamcmd安裝帕魯后端客戶端連接附錄&#xff1a;PalServer.sh的啟動項附錄&#xff1a;配置文件 帕魯官方文檔 https://tech.palworldgame.com/ 手動安裝steamcmd 創建steam用戶 sudo useradd -m steam sudo passwd steam下載steamc…

你寫HTML的時候,會注重語義化嗎?

其實說到語義化&#xff0c;多年前端開發經驗的老手估計也不會太在意&#xff0c;有時候工期太緊&#xff0c;有時候自己疏忽&#xff0c;也就不那么在意了&#xff0c;直接DIVCSS一把梭下去了。 目錄 什么是HTML 什么是HTML語義化 HTML語義化所帶來的好處 我把CSS樣式引入…

_pickle.UnpicklingError: STACK_GLOBAL requires str

導致這個報錯的原因是我跑yolo的時候修改數據集了&#xff0c;里面的label.cache沒有刪除&#xff0c;咱只要刪除掉緩存就行&#xff01;&#xff01; 我這里是已經刪除掉了&#xff0c;所以圖片里面沒有&#xff0c;一般就是在箭頭所示位置有.cache文件的

Vue3知識總結-4

Vue3知識總結-4 文章目錄 Vue3知識總結-4插槽Slots渲染作用域默認內容具名插槽插槽中的數據傳遞具名插槽傳遞數據 組件聲明周期聲明周期示意圖 組件生命周期的應用動態組件組件保持存活組件被卸載 異步組件依賴注入 插槽Slots 在某些場景中&#xff0c;可能想要為子組件傳遞一…

xxljob分片廣播+多線程實現高效定時同步elasticsearch索引庫

需求&#xff1a;為了利用elasticsearch實現高效搜索&#xff0c;需要將mysql中的數據查出來&#xff0c;再定時同步到es里&#xff0c;同時在同步過程中通過分片廣播多線程提高同步數據的效率。 1. 添加映射 使用kibana添加映射 PUT /app_info_article {"mappings&quo…

HL7協議

提示&#xff1a;文章寫完后&#xff0c;目錄可以自動生成&#xff0c;如何生成可參考右邊的幫助文檔 文章目錄 1.介紹2.傳輸協議規范2.1. MLLP2.1.1. 數據頭定義2.1.2. 轉義字符集 2.2. 規范說明2.3. 消息格式說明 3.HL7結構介紹3.1. 患者建檔&#xff08;ADT^A28&#xff09;…

linux c++獲取當前程序的運行路徑

比如我的程序名為:aaa 存放路徑是:/homo/code/ 我在/home/ccc 目錄執行shell文件。shell文件的內容為 #!/bin/bash /homo/code/aaa我希望獲取的路徑是 /homo/code/ 而不是腳本的路徑 給出完整接口代碼 #include <iostream> #include <string> #include <stri…

人工智能領域向量化技術加速多模態大模型訓練與應用

目錄 前言1、TextIn文檔解析技術1.1、文檔解析技術1.2、目前存在的問題1.2.1、不規則的文檔信息示例 1.3、合合信息的文檔解析1.3.1、合合信息的TextIn文檔解析技術架構1.3.2、版面分析關鍵技術 Layout-engine1.3.3、文檔樹提取關鍵技術 Catalog-engine1.3.4、雙欄1.3.5、非對稱…

matlab實現馬爾科夫鏈

在MATLAB中實現馬爾科夫鏈算法通常涉及定義狀態轉移矩陣、初始化狀態向量以及迭代狀態轉移過程。以下是一個簡單的步驟和示例代碼&#xff0c;用于演示如何在MATLAB中實現馬爾科夫鏈。 步驟 定義狀態轉移矩陣&#xff1a;狀態轉移矩陣P描述了從一個狀態轉移到另一個狀態的概率…

注冊海外公司為什么?

注冊海外公司通常是為了實現以下目標之一&#xff1a; 國際化業務擴張&#xff1a; 一些企業可能希望在海外注冊子公司&#xff0c;以便在國際市場上開展業務。這樣的公司可能是跨國企業&#xff0c;已經在多個國家有業務&#xff0c;或者是希望進入新的國際市場的企業。 稅收…

計算機服務器中了locked勒索病毒怎么解決,locked勒索病毒解密恢復工具

在網絡技術飛速發展的時代&#xff0c;通過網絡開展各項工作業務成為眾多企業的首選&#xff0c;網絡也為企業的生產運營提供了極大便利&#xff0c;大大提升了企業辦公效率&#xff0c;但是利用網絡避免不了網絡威脅的存在&#xff0c;數據安全問題一直是企業關心的主要話題。…

不知道代理IP怎么挑?一文帶你了解挑選的關鍵點!

IP代理在如今的網絡環境中扮演者至關重要的角色。通過使用代理IP&#xff0c;可以增強用戶個人信息和網絡的安全。但想要挑選到適合自己的代理IP&#xff0c;并非是一件易事。今天就為大家帶來挑選代理IP的關鍵注意點&#xff0c;幫你輕松篩選出最佳的選擇。 穩定性與速度&…