MySQL學習筆記(9):索引

来源:https://www.cnblogs.com/garvenc/archive/2020/07/02/mysql_learning_9_index.html
-Advertisement-
Play Games

本文更新於2019-07-27,使用MySQL 5.7,操作系統為Deepin 15.4。 在創建一個n列的複合索引時,實際是創建了n個索引。可利用索引中最左邊的列集來匹配行,這樣的列集稱為最左首碼。 InnoDB表中的記錄會按一定順序存儲。如果有主鍵,則按主鍵順序;如果沒有主鍵但有唯一索引,則按唯 ...


本文更新於2019-07-27,使用MySQL 5.7,操作系統為Deepin 15.4。

目錄

在創建一個n列的複合索引時,實際是創建了n個索引。可利用索引中最左邊的列集來匹配行,這樣的列集稱為最左首碼。

InnoDB表中的記錄會按一定順序存儲。如果有主鍵,則按主鍵順序;如果沒有主鍵但有唯一索引,則按唯一索引順序;如果既沒有主鍵也沒有唯一索引,則會生成內部列,按內部列順序。InnoDB的普通索引都會保存主鍵的值。

索引是在存儲引擎層中實現的,而不是在伺服器層實現的,所以每種存儲引擎的索引不一定相同,也不是所有的存儲引擎都支持所有的索引類型。

索引按存儲數據結構可分為:

  • BTREE索引:適用於全關鍵字、關鍵字範圍、關鍵字首碼查詢。最左首碼匹配原則是BTREE索引使用的首要原則。大部分存儲引擎都支持BTREE索引,MyISAM和InnoDB預設使用BTREE索引。
  • HASH索引:適用於全關鍵字查詢,不適用於範圍查詢。只有MEMORY存儲引擎支持HASH索引,預設使用HASH索引,也支持BTREE索引。
  • RTREE索引:即空間(SPATIAL)索引,主要用於地理空間數據類型。只有MyISAM存儲引擎支持RTREE索引。
  • FULLTEXT索引:即全文索引。只有MyISAM存儲引擎支持FULLTEXT索引,只限於CHARVARCHARTEXT列,索引總是對整個列進行的,不支持首碼索引。

索引也可以具有以下作用:

  • 主鍵(PRIMARY)索引
  • 唯一(UNIQUE)索引
  • 首碼索引:對列的前面一部分進行索引。ORDER BYGROUP BY無法使用首碼索引。

註意,索引的長度限制以位元組為單位,DDL語句中的長度表示字元數,在使用多位元組字元集時,欄位長度不能超過索引的最大位元組長度限制。

能夠使用索引的典型場景

  1. 匹配全值:對索引中的所有列都指定具體的值。如對索引a, b, c,執行WHERE a=1 AND b=2 AND c=3
  2. 匹配值的範圍查詢:對索引的值能夠進行範圍查找。如對索引a,執行WHERE a>1
  3. 匹配最左首碼:僅僅使用索引最左邊的列進行查找。如對索引a, b, c,執行WHERE a=1
  4. 僅僅對索引進行查詢,效率更高。如對索引a, b, c,執行SELECT c FROM tbl WHERE a=1
  5. 匹配列首碼:僅僅使用索引中的第一列,並且只包含索引第一列開頭一部分進行查找。如對索引a, b, c,執行WHERE a like 'xxx%'
  6. 能夠實現索引部分精確匹配而其他部分進行範圍匹配。如對索引a, b, c,執行WHERE a=1 AND b>1
  7. 如果列名是索引,使用IS NULL就會使用索引(區別於Oracle)。如對索引a,執行WHERE a IS NULL
  8. 使用ICP(Index Condition Pushdown)特性,可將某些情況下的條件過濾操作下放到存儲引擎層完成,降低不必要的IO訪問。

存在索引但不能使用索引的典型場景

  1. %開頭的LIKE查詢不能利用BTREE索引。一般推薦使用全文索引。或利用InnoDB都是聚簇表的特點,採取一種輕量級的解決方式:索引通常比表小,InnoDB表上的二級索引除存儲欄位值外,還有主鍵值。通過掃描二級索引獲取滿足條件的主鍵列表後,根據主鍵回表檢索記錄,可避開全表掃描。
  2. 數據類型出現隱式轉換時也不會使用索引。
  3. 複合索引的情況下,如果查詢條件不包含索引列最左邊的部分,即不滿足最左首碼,則不會使用複合索引。
  4. 如果MySQL估計使用索引比全表掃描更慢,則不使用索引。
  5. OR分隔的條件,如前面的列有索引,後面的列沒有索引,那麼所有索引都不會被使用。因為後面的條件沒有索引,肯定需要全表掃描,沒必要增加索引的IO訪問。

查看索引使用情況

可以通過SHOW STATUS查看索引使用情況:

  • Handler_read_key:一個行被索引值讀的次數。高表示索引被經常使用。
  • Handler_read_rnd_next:在數據文件中讀下一個行的次數。高表示索引不經常使用,進行大量的表掃描。

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

-Advertisement-
Play Games
更多相關文章
  • Docker安裝單機版ELK日誌收集系統 概述 現在Elasticsearch是比較火的, 很多公司都在用. 而Docker也正如火如荼, 所以我就使用了Docker來安裝ELK, 這裡會詳細介紹下安裝的細節以及需要註意的地方. 先來強調一下, Elasticsearch和Kibana必須用相同版本 ...
  • 技術棧:python + scrapy + tor 為什麼要單獨開這麼一篇隨筆,主要還是在上一篇隨筆"一個小爬蟲的整體解決方案"(https://www.cnblogs.com/qinyulin/p/13219838.html)中沒有著重介紹Scrapy,包括後面幾天也對代碼做了Review,優化了 ...
  • du -sh #統計當前目錄的大小,以直觀方式展現 du -h --max-depth=1 #查看當前目錄下所有一級子目錄文件夾大小 du -h --max-depth=1 | sort #查看當前目錄下所有一級子目錄文件夾大小併排序 du -h --max-depth=1 | grep [TG] ...
  • 參見:https://www.cnblogs.com/Dylansuns/p/6974272.html Linux安裝JDK完整步驟檢查一下系統中的jdk版本[hadoop@master ~]$ java -versionopenjdk version "1.8.0_222-ea"OpenJDK R... ...
  • 前言 閑暇之時,羚羊給大家分享一下羚羊在Centos7 下安裝Cloudera Manager 6.3.0和cloudera cdh 6.3.2的過程和安裝過程中遇到的坑。至於為什麼要選擇CDH,Cloudera Manager和cdh是什麼,之間又是什麼關係,在這裡羚羊就不做介紹了。 為什麼選擇C ...
  • 一、Spark SQL簡介 Spark SQL是Spark用來處理結構化數據的一個模塊,它提供了一個編程抽象叫做DataFrame並且作為分散式SQL查詢引擎的作用。 為什麼要學習Spark SQL?我們已經學習了Hive,它是將Hive SQL轉換成MapReduce然後提交到集群上執行,大大簡化 ...
  • 一.說明 oracle 的exp/imp命令用於實現對資料庫的導出/導入操作; exp命令用於把數據從遠程資料庫server導出至本地,生成dmp文件; imp命令用於把本地的資料庫dmp文件從本地導入到遠程的Oracle資料庫中。 二.語法 能夠通過在命令行輸入 imp help=y 獲取imp的 ...
  • create directory mydata as '邏輯目錄路徑'; 例如: create directory mydata as '/data/oracle/oradata/mydata'; grant read,write on directory mydata to public sele ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...