索引——談談你對索引的認識和理解

来源:https://www.cnblogs.com/lverkou/archive/2020/06/09/13081914.html
-Advertisement-
Play Games

為什麼要用索引? 一般的應用系統,讀寫比例在10:1左右,插入操作和一般的更新操作很少出現性能問題,在生產環境中,我們遇到最多的,也是最容易出問題的,還是一些複雜的查詢操作,因此對查詢語句的優化顯然是重中之重。說起加速查詢,就不得不提到索引了。 索引是什麼? 索引在MySQL中也叫做“鍵”,是存儲引 ...


為什麼要用索引?

一般的應用系統,讀寫比例在10:1左右,插入操作和一般的更新操作很少出現性能問題,在生產環境中,我們遇到最多的,也是最容易出問題的,還是一些複雜的查詢操作,因此對查詢語句的優化顯然是重中之重。說起加速查詢,就不得不提到索引了。

索引是什麼?

索引在MySQL中也叫做“鍵”,是存儲引擎用於快速找到記錄的一種數據結構。

索引對於良好的性能非常關鍵,尤其是當表中的數據量越來越大時,索引對於性能的影響愈發重要。

索引優化應該是對查詢性能優化最有效的手段了。索引能夠輕易將查詢性能提高好幾個數量級。

索引相當於字典的音序表,如果要查某個字,如果不使用音序表,則需要從幾百頁中逐頁去查。

索引原理:

與我們查閱圖書所用的目錄是一個道理:先定位到章,然後定位到該章下的一個小節,然後找到頁數。相似的例子還有:查字典,查火車車次,飛機航班等.

本質都是:通過不斷地縮小想要獲取數據的範圍來篩選出最終想要的結果,同時把隨機的事件變成順序的事件,也就是說,有了這種索引機制,我們可以總是用同一種查找方式來鎖定數據。

索引兩大類型:

hash類型的索引:查詢單條快,範圍查詢慢

btree類型的索引:b+樹,層數越多,數據量指數級增長(我們就用它,因為innodb預設支持它)

 

索引的功能:加速查找,約束功能

適合建索引的欄位:

  1. 經常被查詢的欄位,即在where子句中出現的欄位
  2. 在分組的欄位,即在group by子句中出現的欄位
  3. 存在依賴關係的子表和父表之間的聯合查詢,即主鍵或外鍵欄位
  4. 設置唯一完整性約束的欄位

不適合建索引欄位:

  1. 在查詢中很少被使用的欄位
  2. 擁有許多重覆值的欄位

創建索引:

創建索引:就是在表的一個欄位或者多個欄位上建立索引

普通索引index:加速查找

唯一索引:

  • 主鍵索引(primary key):加速查找+約束(不為空、不能重覆)
  • 唯一索引(unique):加速查找+約束(不能重覆)

聯合索引:

  • primary key(id,name):聯合主鍵索引
  • unique(id,name):聯合唯一索引
  • index(id,name):聯合普通索引

創建普通索引:

普通索引:創建索引時,不附加任何限制條件(唯一、非空等限制),該索引可以創建在任何列上。

語法:create table 表名(  ...  ,index|key [索引名](列名, [(長度)] [asc|desc]) );      //長度和asc|desc可省略

案例:create table uid( id int, ..., index index_id(id) );

create table uid( id int, 
            ...,
           index index_id(id)
          );

通過explain查看索引是否被執行:

explain select * from uid where id=001;

在已經存在的欄位上建立索引:

語法:create index 索引名 on 表名 (列名 [(長度)] [asc|desc])

 

案例:

create index index_id on uid(id);

通過alter來創建索引:

語法:altert able 表名 add index|key 索引名 (列名 [(長度)] [asc|desc])

案例:

alter table uid add index index_id(id);

創建唯一索引:

唯一索引:就是限制某個或者多個欄位的值必須唯一,通過該類型的索引可以快速的查詢某條記錄

語法:create table 表名(  ... , unique index|key [索引名](列名 [(長度)] [asc|desc]) );

案例:

create table uid(id int,
                 ...,    
                 unique index index_id(id) 
                 );                    

已有的表上建索引:

案例

create unique index index_id on uid(id);

通過alter添加索引:

案例

alter table uid add unique index index_id(id);

創建全文索引

全文索引主要關聯在數據類型為char、varchar和text的欄位上,以便能夠快速的查詢數據量較大的字元串類型的欄位

語法:create table 表名(  ... , fulltext index|key [索引名](列名 [(長度)] [asc|desc]) );

創建多列索引(聯合索引)

多列索引:是指創建索引的欄位不是一個欄位,而是多個欄位,雖然可以通過關聯的欄位進行查詢,但是只有查詢條件中使用了所關聯的欄位中的第一個欄位,多列索引才會被使用。

語法:create table 表名(  ... , index|key [索引名](列名1 [(長度)] [asc|desc]) ,列名2 [(長度)] [asc|desc]) );

案例

create table uid( ..., 
          name varchar(20),
   loc varchar(40),
          index index_name_loc(name, loc)
     );

已經存在的表上創建索引:

案例

create index index_name_loc on uid(name, loc);
alter table uid add index index_name_loc(name,loc);

多個單列索引在多條件查詢時只會生效第一個索引!所以多條件聯合查詢時最好建聯合索引!

最左首碼原則:

顧名思義是最左優先,以最左邊的為起點任何連續的索引都能匹配上,

註:如果第一個欄位是範圍查詢需要單獨建一個索引

註:在創建聯合索引時,要根據業務需求,where子句中使用最頻繁的一列放在最左邊。這樣的話擴展性較好,比如 userid 經常需要作為查詢條件,而 mobile 不常常用,則需要把 userid 放在聯合索引的第一位置,即最左邊

聯合索引本質:

當創建(a,b,c)聯合索引時,相當於創建了(a)單列索引,(a,b)聯合索引以及(a,b,c)聯合索引

想要索引生效的話,只能使用 a,和a,b,和a,b,c三種組合;當然,我們上面測試過,a,c組合也可以,但實際上只用到了a的索引,c並沒有用到!

聯合索引總結:

需要加索引的欄位,要在where條件中;

數據量少的欄位不需要加索引(因為建索引有開銷,速度反而慢);

如果where條件中是or關係,加索引不起作用;

聯合索引比每個列分別建索引更有優勢,因為建索引有開銷,順序也要註意,一般不超過7,8個,應該將嚴格的索引放在前面,這樣篩選力度會更大,效率更高。

刪除索引:

語法:drop index index_name on table_name;

 

案例

drop index index_id on uid;

 

 

 

 

 

參考文獻:

https://www.cnblogs.com/bypp/p/7755307.html

https://blog.csdn.net/fengxiaolu311/article/details/82716294


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

-Advertisement-
Play Games
更多相關文章
  • 首先我們來看一段控制台應用代碼: class Program { static async Task Main(string[] args) { System.Console.WriteLine($"Thread Id is Thread:{Thread.CurrentThread.ManagedT ...
  • 《ASP.NET 框架應用程式實戰》 [作者] (中) 李發陵 冷亞洪[出版] 清華大學出版社[版次] 2017年01月 第1版[印次] 2017年01月 第1次 印刷[定價] 47.00元 【第02章】 (P023) 目前, ASP.NET MVC 4 已內置於 Visual Studio 201 ...
  • 1、引導界面美化 下載grub主題 https://www.gnome-look.org/browse/cat/109/order/latest/ https://www.pling.com/s/Gnome/browse/cat/109/order/latest/ 隨便下一個主題 配置主題 cd / ...
  • 1、應啟用安全審計功能,審計覆蓋到每個用戶,對重要的用戶行為和重要安全事件進行審計 方案: 在管理工具打開本地安全策略,打開路徑:安全設置\本地策略\審核策略,將全部審核策略配置為:成功,失敗。包括審核策略更改、審核對象訪問、審核進程跟蹤、審核目錄服務訪問、審核賬戶登陸事件、審核特權使用、審核系統事 ...
  • 大家好,我是良許。 在 Linux 下,重命名一個文件,我們通常是使用 mv 命令,一般是這樣操作的: $ mv file1.txt file2.txt 這樣重命令的方式當然是可以,但有個弊端就是你需要輸入兩次文件名。文件名比較短還好,一旦比較長的話,輸兩次會很讓人崩潰的。 本文就介紹幾種更高效的文 ...
  • 記憶體在人工智慧解決方案(例如機器學習)的培訓和實施中均扮演著關鍵角色。這也是創建諸如5G之類的高級網路技術的要求,這將需要在網路邊緣以及在端點處進行處理和存儲以實現IoT和其他應用程式。 如今大多數高性能記憶體都是易失性的,這意味著當設備斷電時,存儲在記憶體中的所有內容都會丟失。但是記憶體會消耗很多功率, ...
  • Autohotkey是一款輕量小眾但高效免費開源的windows熱鍵腳本語言,游戲操縱、滑鼠操作、鍵盤快捷重定義,快捷短語等等,只有你想不到,沒有它做不到,神器中的神器呀,相見恨晚。 ...
  • 1. Kubernetes是什麼 Kubernetes中文版資料 Kubernetes是容器集群管理系統,是一個開源的平臺,可以實現容器集群的自動化部署、自動擴縮容、維護等功能。 通過Kubernetes我們可以: 快速部署應用 快速擴展應用 無縫對接新的應用功能 * 節省資源,優化硬體資源的使用 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...