MYSQL5.7 INDEXES之如何使用索引(一)

来源:https://www.cnblogs.com/semonshi/archive/2019/11/27/11941436.html

Most MySQL indexes (PRIMARY KEY, UNIQUE, INDEX, and FULLTEXT) are stored in B-trees. Exceptions: Indexes on spatial data types use R-trees; MEMORY tab ...


Most MySQL indexes (PRIMARY KEYUNIQUEINDEX, and FULLTEXT) are stored in B-trees. Exceptions: Indexes on spatial data types use R-trees; MEMORY tables also support hash indexesInnoDB uses inverted lists for FULLTEXT indexes

B-Tree

A tree data structure that is popular for use in database indexes. The structure is kept sorted at all times, enabling fast lookup for exact matches (equals operator) and ranges (for example, greater than, less than, and BETWEEN operators). This type of index is available for most storage engines, such as InnoDB and MyISAM.

Because B-tree nodes can have many children, a B-tree is not the same as a binary tree, which is limited to 2 children per node.

Contrast with hash index, which is only available in the MEMORY storage engine. The MEMORY storage engine can also use B-tree indexes, and you should choose B-tree indexes for MEMORY tables if some queries use range operators.

B樹索引:可以在使用表達式中使用的對列的比較 =, >, >=, <, <=,或BETWEEN運營商。LIKE 如果to的參數LIKE是不以通配符開頭的常量字元串,則索引也可以用於比較.

哈希索引 :只能用來做相等比較,速度快。

MySQL使用索引進行以下操作:

  • WHERE快速 查找與子句匹配的行

  • 從考慮中消除行。如果可以在多個索引之間進行選擇,MySQL通常會使用找到最少行數的索引(最具 選擇性的索引)。

  • 如果表具有多列索引,則優化器可以使用索引的任何最左首碼來查找行。舉例來說,如果你有一個三列的索引 (col1, col2, col3),你有索引的搜索功能(col1), (col1, col2)以及(col1, col2, col3)有關更多信息,請參見 第8.3.5節“多列索引”

  • 執行聯接時從其他表中檢索行。如果聲明相同的類型和大小,MySQL可以更有效地在列上使用索引。在這種情況下, VARCHAR與 CHAR被認為是相同的,如果它們被聲明為相同的大小。例如, VARCHAR(10)和 CHAR(10)是相同的大小,但是 VARCHAR(10)和 CHAR(15)不是。

    對於非二進位字元串列之間的比較,兩個列應使用相同的字元集。例如,將一utf8列與一 latin1進行比較會排除使用索引。

    如果無法在不進行轉換的情況下直接比較值,則比較不同的列(例如,將字元串列與時間或數字列進行比較)可能會阻止使用索引。對於給定的值,如1在數值列,它可能比較等於在字元串列,例如任何數量的值 '1'' 1', '00001',或'01.e1'這排除了對字元串列使用任何索引的可能性。

  • 查找特定索引列MIN()或 MAX()key_col這由預處理器優化,該預處理器檢查您是否正在使用 索引中之前出現的所有關鍵部分在這種情況下,MySQL對每個表達式或 表達式進行一次鍵查找,並將其替換為常量。如果所有表達式都用常量替換,查詢將立即返回。例如: WHERE key_part_N =constantkey_colMIN()MAX()

    SELECT MIN(key_part2),MAX(key_part2)
      FROM tbl_name WHERE key_part1=10;
  • 如果排序或分組是在可用索引的最左首碼(例如上完成的,則對錶進行排序或分組 如果所有關鍵部分後面都有,則按相反順序讀取密鑰。請參見 第8.2.1.14節“按優化排序”和 第8.2.1.15節“按優化分組”。 ORDER BY key_part1key_part2DESC

  • 在某些情況下,可以優化查詢以檢索值而無需查詢數據行。(為查詢提供所有必要結果的索引稱為 覆蓋索引。)如果查詢僅從表中使用某些索引中包含的列,則可以從索引樹中檢索所選值,以提高速度:

    SELECT key_part3 FROM tbl_name
      WHERE key_part1=1

對於報表查詢處理大多數或所有行的小型表或大型表,索引的重要性不那麼重要。當查詢需要訪問大多數行時,順序讀取要比處理索引快。順序讀取可以最大程度地減少磁碟查找,即使查詢不需要所有行。有關詳細信息請參見第8.2.1.20節“避免全表掃描”

 

 


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

更多相關文章
一周排行
  • 比如要拆分“呵呵呵90909086676喝喝999”,下麵當type=0返回的是中文字元串“呵呵呵,喝喝”,type=1返回的是數字字元串“90909086676,999”, private string GetStrings(string str,int type=0) { IList<strin ...
  • Swagger一個優秀的Api介面文檔生成工具。Swagger可以可以動態生成Api介面文檔,有效的降低前後端人員關於Api介面的溝通成本,促進項目高效開發。 1、使用NuGet安裝最新的包:Swashbuckle.AspNetCore。 2、編輯項目文件(NetCoreTemplate.Web.c ...
  • 2020 年 7 月 30 日, 由.NET基金會和微軟 將舉辦一個線上和為期一天的活動,包括 微軟 .NET 團隊的演講者以及社區的演講者。本次線上大會 專註.NET框架構建微服務,演講者分享構建和部署雲原生應用程式的最佳實踐、模式、提示和技巧。有關更多信息和隨時瞭解情況:https://focu... ...
  • #abp框架Excel導出——基於vue #1.技術棧 ##1.1 前端採用vue,官方提供 UI套件用的是iview ##1.2 後臺是abp——aspnetboilerplate 即abp v1,https://github.com/aspnetboilerplate/aspnetboilerp ...
  • 前言 本文的文字及圖片來源於網路,僅供學習、交流使用,不具有任何商業用途,版權歸原作者所有,如有問題請及時聯繫我們以作處理。 作者:碧茂大數據 PS:如有需要Python學習資料的小伙伴可以加下方的群去找免費管理員領取 input()輸入 Python提供了 input() 內置函數從標準輸入讀入一 ...
  • 從12年到20年,python以肉眼可見的趨勢超過了java,成為了當今It界人人皆知的編程語言。 python為什麼這麼火? 網路編程語言搜索指數 適合初學者 Python具有語法簡單、語句清晰的特點,這就讓初學者在學習階段可以把精力集中在編程對象和思維方法上。 大佬都在用 Google,YouT ...
  • 在社會上存在一種普遍的對培訓機構的學生一種歧視的現象,具體表現在,比如:當你去公司面試的時候,一旦你說了你是培訓機構出來的,那麼基本上你就涼了,那麼你瞞著不說,然後又通過了面試成功入職,但是以後一旦在公司被髮現有培訓經歷,可能會面臨被降薪,甚至被辭退,培訓機構出來的學生,在用人單位眼裡就是能力低下的 ...
  • from typing import List# 這道題看了大佬寫的代碼,經過自己的理解寫出來了。# 從最外圍的四周找有沒有為O的,如果有的話就進入深搜函數,然後深搜遍歷# 判斷上下左右的位置是否為Oclass Solution: def solve(self, board: List[List[s ...
  • import requests; import re; import os; # 1.請求網頁 header = { "user-agent":'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_5) AppleWebKit/537.36 (KHTML, li ...
  • import requests; import re; import os; import parsel; 1.請求網頁 header = { "user-agent":'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_5) AppleWebKit/537. ...