掌握這13個MySQL索引知識點,讓你面試通過率翻倍

来源:https://www.cnblogs.com/lfs2640666960/archive/2020/02/14/12308306.html
-Advertisement-
Play Games

資料庫索引是資料庫系統中一個重要的概念,索引也叫做 key ,是一種用於提升資料庫查詢效率的數據結構,我們可以把索引理解成一本書的目錄,通過目錄我們可以快速找到對應章節的內容,同樣的,通過資料庫索引,我們可以快速找到數據表中對應的記錄。 ...


 

 

資料庫索引有關的知識,說實在的,真的是很複雜,本來想好好看看這方面的東西,然後寫篇文章詳細談談的,後來發現索引的知識太難太深,要談得全面又詳細真的很難,所以最後還是把自己學到的和想到的變成下麵一個個的問題,希望能對大家幫助!

知識點

問題1:什麼是資料庫索引?

資料庫索引是資料庫系統中一個重要的概念,索引也叫做 key ,是一種用於提升資料庫查詢效率的數據結構,我們可以把索引理解成一本書的目錄,通過目錄我們可以快速找到對應章節的內容,同樣的,通過資料庫索引,我們可以快速找到數據表中對應的記錄。

總而言之,索引就像給數據表建了一個目錄一樣。

問題2:為什麼在使用索引?

1 . 使用索引大大減少了存儲引擎需要掃描的數據量,如果沒有使用索引的話,每查詢一行數據都要對數據表進行掃描,這樣的話會非常慢。

2 . 由於索引已經排好序的,所以對數據表進行 ORDER BY 和 GROUP BY 等操作時,可以很快得到結果。

3 . 索引可以將隨機的 I/O 轉為順序的 I/O ,避免高昂的磁碟 IO 成本,提升查詢效率。

問題3:MySQL索引在哪個模塊中實現的?

MySQL 的索引是在存儲引擎這一層實現的,因此每一種存儲引擎都有不同的實現方式,對同一種索引的處理方式也完成不同。

問題4:為什麼設置了索引卻不起作用?

如果使用以 % 開頭的 LIKE 語句進行模糊匹配,則無法使用索引,如:

SELECT * FROM users WHERE name LIKE '%小張%';

SELECT * FROM users WHERE name LIKE '%小張';
複製代碼

 

不過以 % 為結尾則可以使用索引,如:

SELECT * FROM users WHERE name LIKE '張%';
複製代碼

 

OR 語句前後沒有同時使用索引,比如下麵的語句, 欄位id 有索引,而 欄位name 沒有創建索引,那麼下麵的語句只能全表掃描,無法用到索引:

SELECT * FROM users id = 10 or name='test'
複製代碼

 

問題5:MySQL索引底層使用什麼數據結構?

在 MySQL 中,大部分情況下,索引都是使用 B-Tree 作為底層數據結構, B-Tree 只是一種泛稱,實際上不同的存儲引擎使用 B-Tree 時,有不同的變種,比如 InnoDB 使用的是 B+Tree 。

另外也有一些特殊的索引結構,比如哈希索引,哈希索引底層則使用的是哈希表,在 MySQL中,只有 Memory 存儲引擎支持哈希索引。

問題6:什麼情況下數據表不適合創建索引?

1 . 對於用於存儲歸檔歷史數據的且很少用於查詢的數據表,不建議創建索引。

2 . 數據量比較小的數據表,而且未來數據也不會有太大增長的數據,不應該建索引,比如用於保存配置的數據表。

3 . 修改頻繁,且修改性能遠大於查詢性能時,不應該再創建索引。

問題7:什麼是回表?

回表是對Innodb存儲引擎而言的,在 InnoDB 存儲引擎中,主鍵索引的葉子節點存儲的記錄的數據,而普通索引的葉子節點存儲的主鍵索引的地點。

當我們通過主鍵查詢時,只需要搜索主鍵索引的搜索樹,直接可以得到記錄的數據。

當我們通過普通索引進行查詢時,通過搜索普通索引的搜索樹得到主鍵的地址之後,還要再使用該主鍵對主鍵搜索樹進行搜索,這個過程稱為回表。

問題8:聚簇索引與非聚簇索引的區別?

聚簇索引:聚簇索引的順序就是數據的物理存儲順序,並且索引與數據放在一塊,通過索引可以直接獲取數據,一個數據表中僅有一個聚簇索引。

非聚簇索引:索引順序與數據物理排列順序無關,索引文件與數據是分開存放。

問題9:MySQL主鍵索引、唯一索引與普通索引的區別?

設置為主鍵索引的欄位不允許為 NULL ,而且一張數據表只能有一個主鍵索引。

設置為唯一索引的欄位,其欄位值不允許重要。

普通索引可以包含重覆的值,也可以為 NULL 。

問題10:索引可以提高查詢性能,那是不是索引創建越多越好?

索引作為一個數據表的目錄,本身的存儲就需要消耗很多的磁碟和記憶體存儲空間。

並助在寫入數據表數據時,每次都需要更新索引,所以索引越多,寫入就越慢。

尤其是糟糕的索引,建得越多對資料庫的性能影響越大。

問題11:MyISAM與InnoDB在處理索引上有什麼不同?

MyISAM 存儲引擎是非聚族索引,索引與數據是分開存儲的,索引文件中記錄了數據的指針

而 InnoDB 存儲引擎是聚族索引,即索引跟數據是放在一塊的, InnoDB 一般將主鍵與數據放在一塊,如果沒有主鍵,則將 unique key 作為主鍵,如果沒有 unique key ,則自動創建一個 rowid 作為主鍵,其他二級索引葉子指針存儲的是主鍵的位置。

問題12:什麼是索引的最左首碼原則?

MySQL 資料庫不單可以為單個數據列創建索引,也可以為多個數據列創建一個聯合索引,比如:

CREATE TABLE test(
    a INT NOT NOT,
    b INT NOT NOT,
    KEY(a,b)
);
複製代碼

 

當我們使用下麵的查詢語句時,由於 WHERE 語句中查詢的條件就是聯合索引,所以可以很快查詢到數據。

SELECT * FROM test WHERE a=1 AND b=1; 
複製代碼

 

同樣,下麵的語句也會利用上面創建的聯合索引,這是因為 MySQL 會按照索引創建的順序進行排序,然後根據查詢條件從索引最左邊開始檢測查詢條件是否滿足該索引,由於欄位 a 在最左邊,所以滿足索引。

SELECT * FROM test WHERE a=1; 
複製代碼

 

而使用 欄位b 進行查詢時,則為滿足,因為從最左邊匹配到的是 欄位a ,所以 MySQL 判斷為不滿足索引條件。

SELECT * FROM test WHERE b=1; 
複製代碼

 

從上面例子可以很好地瞭解索引的最左首碼原則,同時也說明瞭索引順序的重要性。

問題13:什麼是覆蓋索引?

如果一個索引中包含查詢所要的欄位時,此時不需要再回表查詢,我們就稱該索引為覆蓋索引。

比如下麵的查詢中,欄位id是主鍵索引,所以可以直接返回索引的值,顯著提升了查詢的性能。

SELECT id FROM users WHERE id BETWEEN 10 AND 20;
複製代碼

 

小結

當然,上面列出的只是索引的一小部分知識點,有什麼回答不對的地方,歡迎指出。

想要閱讀更多精彩內容,可以關註我的微信公眾號:Java技術zhai,這是我的私人公眾號,專註於Java技術分享,期待你的參與。


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

-Advertisement-
Play Games
更多相關文章
  • 在WPF用戶界面中,繪製2D圖形內容的最簡單方法是使用形狀(shape)——專門用於表示簡單的直線、橢圓、矩形以及多變形的一些類。從技術角度看,形狀就是所謂的繪圖圖元(primitive)。可組合這些基本元素來創建更複雜的圖形。 關於WPF中形狀的重要細節是,它們都繼承自FrameworkEleme ...
  • Blend 修改TreeViewItem樣式 1、用Blend for Visual Studio 2019 新建Wpf項目,拖動一個TreeView控制項到Grid上 2、在繪圖視窗選中TreeViewItem,右鍵編輯模版 編輯副本 3、繪製水平、垂直虛線( "參考博文" ) 在TreeViewI ...
  • ASPNetCore 發佈到IIS 準備工作 1.1. 安裝IIS。(具體操作不再說明) 安裝成功後再瀏覽器輸入localhost得到的頁面如下 1.2. 安裝dotnet-hosting-2.2.2-win.exe安裝成功後在IIS 中可以看到如下兩個程式 這兩個程式對應得NetCore的版本不一 ...
  • 1.Ctrl+s:快速保存代碼 一定要記得隨時隨地用 Ctrl+s 來保存我們的代碼哦!!!不然等到電腦關機或者是使用的Eclipse突然閃退就欲哭無淚了。此時腦海裡就突然出現了嗶嗶嗶的畫面~ 2.Alt+/:自動補全代碼或者提示代碼後半部分 牆裂推薦大家使用啊,真的是超級好用了。 給大家舉一個例子 ...
  • 在看 apue 第 19 章偽終端第 6 節使用 pty 程式時,發現“檢查長時間運行程式的輸出”這一部分內容的實際運行結果,與書上所說有出入。 於是展開一番研究,最終發現是書上講的有問題,現在摘出來讓大家評評理。 先上代碼 pty.c pty_fun.c 這是書上標準的 pty 程式,簡單說起來就 ...
  • 背景介紹 我們在工作中難免會寫一些重覆性的代碼,所以需要我們具備一定的抽象能力,比如把共同的邏輯抽取到抽象類中,也可以通過一些工具類來避免冗餘代碼 今天這篇文章就是把一個調用服務的重試功能抽取出一個工具類,以備復用。這裡為了方便介紹,把調用服務簡化成方法的調用,被調用的 foo 方法如下: ~~~ ...
  • 1 SQL 的哲學 形如 Linux 哲學一切都是文件,在 SQL 領域也有這樣一條至理名言 2 關係資料庫 所謂關係資料庫(Relational database)是創建在關係模型基礎上的資料庫,藉助於集合代數等數學概念和方法來處理資料庫中的數據。 現實世界中的各種實體以及實體之間的各種聯繫均用關 ...
  • 該文為《 MySQL 實戰 45 講》的學習筆記,感謝查看,如有錯誤,歡迎指正 一、索引簡介 索引就類似書本的目錄,作用就是方便我們更加快速的查找到想要的數據。 索引的實現方式比較多,常見的有 ,`有序數組 搜索樹`。 1.1 哈希表 是將數據以 的形式存儲起來,簡單來說就是將 通過哈希函數換算成數 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...