婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 新手學習MySQL索引

新手學習MySQL索引

熱門標簽:昌德訊外呼系統 400電話申請廠家現貨 福建外呼電銷機器人加盟 百度地圖標注要什么軟件 天津公司外呼系統軟件 電話機器人的價格多少錢一個月 中國地圖標注公司 自己做地圖標注需要些什么 徐涇鎮騰訊地圖標注

前言

由于MySQL的索引中最重要的數據結構就是B+樹,所以前面我們先大概講講B+樹的原理

B+ Tree 原理

1. 數據結構

B Tree 指的是 Balance Tree,也就是平衡樹。平衡樹是一顆查找樹,并且所有葉子節點位于同一層。

B+ Tree 是基于 B Tree 和葉子節點順序訪問指針進行實現,它具有 B Tree 的平衡性,并且通過順序訪問指針來提高區間查詢的性能。

在 B+ Tree 中,一個節點中的 key 從左到右非遞減排列,如果某個指針的左右相鄰 key 分別是 keyi 和 keyi+1,且不為 null,則該指針指向節點的所有 key 大于等于 keyi 且小于等于 keyi+1。

2. 操作

進行查找操作時,首先在根節點進行二分查找,找到一個 key 所在的指針,然后遞歸地在指針所指向的節點進行查找。直到查找到葉子節點,然后在葉子節點上進行二分查找,找出 key 所對應的 data。

插入刪除操作會破壞平衡樹的平衡性,因此在插入刪除操作之后,需要對樹進行一個分裂、合并、旋轉等操作來維護平衡性。

3. 與紅黑樹的比較

紅黑樹等平衡樹也可以用來實現索引,但是文件系統及數據庫系統普遍采用 B+ Tree 作為索引結構,主要有以下兩個原因:

(一)更少的查找次數

平衡樹查找操作的時間復雜度等于樹高 h,而樹高大致為 O(h)=O(logdN),其中 d 為每個節點的出度。

紅黑樹的出度為 2,而 B+ Tree 的出度一般都非常大,所以紅黑樹的樹高 h 很明顯比 B+ Tree 大非常多,查找的次數也就更多。

(二)利用磁盤預讀特性       

為了減少磁盤 I/O,磁盤往往不是嚴格按需讀取,而是每次都會預讀。預讀過程中,磁盤進行順序讀取,順序讀取不需要進行磁盤尋道,并且只需要很短的旋轉時間,速度會非常快。       

操作系統一般將內存和磁盤分割成固態大小的塊,每一塊稱為一頁,內存與磁盤以頁為單位交換數據。數據庫系統將索引的一個節點的大小設置為頁的大小,使得一次 I/O 就能完全載入一個節點。并且可以利用預讀特性,相鄰的節點也能夠被預先載入。

MySQL 索引

索引是在存儲引擎層實現的,而不是在服務器層實現的,所以不同存儲引擎具有不同的索引類型和實現。

1. B+Tree 索引

是大多數 MySQL 存儲引擎的默認索引類型。

因為不再需要進行全表掃描,只需要對樹進行搜索即可,所以查找速度快很多。

除了用于查找,還可以用于排序和分組。

可以指定多個列作為索引列,多個索引列共同組成鍵。

適用于全鍵值、鍵值范圍和鍵前綴查找,其中鍵前綴查找只適用于最左前綴查找。如果不是按照索引列的順序進行查找,則無法使用索引。

InnoDB 的 B+Tree 索引分為主索引和輔助索引。主索引的葉子節點 data 域記錄著完整的數據記錄,這種索引方式被稱為聚簇索引。因為無法把數據行存放在兩個不同的地方,所以一個表只能有一個聚簇索引。

輔助索引的葉子節點的 data 域記錄著主鍵的值,因此在使用輔助索引進行查找時,需要先查找到主鍵值,然后再到主索引中進行查找。

2. 哈希索引

哈希索引能以 O(1) 時間進行查找,但是失去了有序性:無法用于排序與分組;只支持精確查找,無法用于部分查找和范圍查找。InnoDB 存儲引擎有一個特殊的功能叫“自適應哈希索引”,當某個索引值被使用的非常頻繁時,會在 B+Tree 索引之上再創建一個哈希索引,這樣就讓 B+Tree 索引具有哈希索引的一些優點,比如快速的哈希查找。

3. 全文索引

MyISAM 存儲引擎支持全文索引,用于查找文本中的關鍵詞,而不是直接比較是否相等。

查找條件使用 MATCH AGAINST,而不是普通的 WHERE。

全文索引使用倒排索引實現,它記錄著關鍵詞到其所在文檔的映射。

InnoDB 存儲引擎在 MySQL 5.6.4 版本中也開始支持全文索引。

4. 空間數據索引

MyISAM 存儲引擎支持空間數據索引(R-Tree),可以用于地理數據存儲。空間數據索引會從所有維度來索引數據,可以有效地使用任意維度來進行組合查詢。必須使用 GIS 相關的函數來維護數據。

索引優化

1. 獨立的列

在進行查詢時,索引列不能是表達式的一部分,也不能是函數的參數,否則無法使用索引。例如下面的查詢不能使用 actor_id 列的索引:

SELECT actor_id FROM sakila.actor WHERE actor_id + 1 = 5;

2. 多列索引

在需要使用多個列作為條件進行查詢時,使用多列索引比使用多個單列索引性能更好。例如下面的語句中,最好把 actor_id 和 film_id 設置為多列索引。

SELECT film_id, actor_ id FROM sakila.film_actor WHERE actor_id = 1 AND film_id = 1;

3. 索引列的順序

讓選擇性最強的索引列放在前面。

索引的選擇性是指:不重復的索引值和記錄總數的比值。最大值為 1,此時每個記錄都有唯一的索引與其對應。選擇性越高,查詢效率也越高。

例如下面顯示的結果中 customer_id 的選擇性比 staff_id 更高,因此最好把 customer_id 列放在多列索引的前面。

SELECT COUNT(DISTINCT staff_id)/COUNT(*) AS staff_id_selectivity,
COUNT(DISTINCT customer_id)/COUNT(*) AS customer_id_selectivity,
COUNT(*)
FROM payment;

staff_id_selectivity: 0.0001
customer_id_selectivity: 0.0373
 COUNT(*): 16049

4. 前綴索引

對于 BLOB、TEXT 和 VARCHAR 類型的列,必須使用前綴索引,只索引開始的部分字符。

對于前綴長度的選取需要根據索引選擇性來確定。

5. 覆蓋索引

索引包含所有需要查詢的字段的值。

具有以下優點:

  • 索引通常遠小于數據行的大小,只讀取索引能大大減少數據訪問量。
  • 一些存儲引擎(例如 MyISAM)在內存中只緩存索引,而數據依賴于操作系統來緩存。因此,只訪問索引可以不使用系統調用(通常比較費時)。
  • 對于 InnoDB 引擎,若輔助索引能夠覆蓋查詢,則無需訪問主索引。

6. 最左前綴原則

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

聯合索引本質:

當創建(a,b,c)聯合索引時,相當于創建了(a)單列索引,(a,b)聯合索引以及(a,b,c)聯合索引 想要索引生效的話,只能使用 a和a,b和a,b,c三種組合。

索引的優點

  • 大大減少了服務器需要掃描的數據行數。
  • 幫助服務器避免進行排序和分組,以及避免創建臨時表(B+Tree 索引是有序的,可以用于 ORDER BY 和 GROUP BY 操作。臨時表主要是在排序和分組過程中創建,因為不需要排序和分組,也就不需要創建臨時表)。
  • 將隨機 I/O 變為順序 I/O(B+Tree 索引是有序的,會將相鄰的數據都存儲在一起)。

索引的使用條件

  • 對于非常小的表、大部分情況下簡單的全表掃描比建立索引更高效;
  • 對于中到大型的表,索引就非常有效;
  • 但是對于特大型的表,建立和維護索引的代價將會隨之增長。這種情況下,需要用到一種技術可以直接區分出需要查詢的一組數據,而不是一條記錄一條記錄地匹配,例如可以使用分區技術。

小結

索引是MySQL中一個很重要的功能,日常開發中如果能用好索引,能大幅度提高SQL語句的執行性能,所以了解其中的原理也是十分必要的。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • 由不同的索引更新解決MySQL死鎖套路
  • 通過唯一索引S鎖與X鎖來了解MySQL死鎖套路
  • 分享幾道關于MySQL索引的重點面試題
  • Mysql中的索引精講
  • 簡單談談Mysql索引與redis跳表
  • MySQL學習(七):Innodb存儲引擎索引的實現原理詳解
  • 使用shell腳本來給mysql加索引的方法
  • MySQL批量插入和唯一索引問題的解決方法
  • 高效利用mysql索引指南

標簽:陜西 北京 荊門 黔西 昌都 鄂爾多斯 駐馬店 梅河口

巨人網絡通訊聲明:本文標題《新手學習MySQL索引》,本文關鍵詞  新手,學習,MySQL,索引,新手,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《新手學習MySQL索引》相關的同類信息!
  • 本頁收集關于新手學習MySQL索引的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    在线观看亚洲a| 婷婷成人激情在线网| 亚洲成人免费观看| av一区二区三区在线| 久久国产精品99久久久久久老狼| 欧美影视一区二区三区| 亚洲精品久久7777| 欧美区视频在线观看| 久久机这里只有精品| 国产精品欧美经典| 国产伦精品一区二区三区视频青涩 | 色老汉一区二区三区| 成人美女在线视频| 国产福利91精品| 成人教育av在线| 色诱视频网站一区| 精品美女一区二区| 天堂资源在线中文精品| 午夜视频一区二区| 欧美精品久久一区二区三区| 免费在线一区观看| 亚洲欧洲精品一区二区三区| 日本网站在线观看一区二区三区| 日韩av中文在线观看| 蜜桃av一区二区三区| 成人国产免费视频| 日韩欧美在线网站| 亚洲bdsm女犯bdsm网站| 高潮精品一区videoshd| 日韩欧美高清一区| 日韩综合小视频| 91女人视频在线观看| 国产日韩欧美a| 国产麻豆精品在线| 亚洲免费伊人电影| 成人美女视频在线观看| 欧美一级日韩一级| 国产美女在线精品| 成人手机电影网| 成人性生交大片免费| 波多野洁衣一区| 精品国产乱码久久久久久影片| 99re热这里只有精品免费视频| 色噜噜夜夜夜综合网| 欧美高清一级片在线| 波多野结衣在线aⅴ中文字幕不卡| 奇米影视一区二区三区小说| jvid福利写真一区二区三区| 蜜桃传媒麻豆第一区在线观看| 国产精品成人免费精品自在线观看| 欧美成人性福生活免费看| 亚洲成人777| 欧美午夜电影一区| 国产suv精品一区二区883| 欧美撒尿777hd撒尿| 亚洲最快最全在线视频| 高清不卡在线观看| 国产午夜三级一区二区三| 成人免费观看av| 欧美日韩不卡一区二区| 99国产欧美另类久久久精品| 国产又粗又猛又爽又黄91精品| 日韩专区中文字幕一区二区| 亚洲一区二区三区四区五区黄| 国产精品国产自产拍高清av王其| 久久精品欧美一区二区三区麻豆| 欧美岛国在线观看| 精品卡一卡二卡三卡四在线| 欧美一区二区三区人| 欧美精品v国产精品v日韩精品| 色视频欧美一区二区三区| 91在线高清观看| 北条麻妃国产九九精品视频| 北条麻妃国产九九精品视频| 99精品欧美一区二区三区综合在线| 成人综合日日夜夜| 99久久精品情趣| 91丨porny丨中文| 奇米精品一区二区三区在线观看一| 国产色综合久久| 欧美影院一区二区| 国产麻豆日韩欧美久久| 一区二区三区四区在线播放| 国产欧美日韩精品在线| 6080国产精品一区二区| 色偷偷久久一区二区三区| 精一区二区三区| 日韩电影在线一区二区三区| 国产91清纯白嫩初高中在线观看| 久久久另类综合| 国产女主播视频一区二区| 国产精品福利一区二区三区| 亚洲欧美日韩电影| 亚洲一卡二卡三卡四卡无卡久久| 精品国产亚洲在线| 91网站视频在线观看| 精品一区二区三区日韩| 免费在线观看一区| 婷婷成人激情在线网| www.欧美亚洲| 美女脱光内衣内裤视频久久网站| 亚洲最色的网站| 一区二区免费在线播放| 日产国产欧美视频一区精品| 亚洲超丰满肉感bbw| 蜜桃av一区二区| 国产精品中文有码| 国产精品自拍三区| 欧美一二三区在线| 欧美日韩国产综合一区二区| 国产精品久久久久桃色tv| 欧美日韩在线观看一区二区 | 国产福利一区二区三区视频在线| 国产99久久久久久免费看农村| 99久久精品国产一区| 欧美体内she精视频| 精品福利一二区| 亚洲日本青草视频在线怡红院 | 99精品欧美一区| 一本到三区不卡视频| 欧美日韩激情在线| 亚洲情趣在线观看| 中文无字幕一区二区三区 | 99re成人精品视频| 精品视频资源站| 亚洲福利视频导航| 久久无码av三级| 亚洲综合成人在线视频| 极品尤物av久久免费看| 欧美性猛交xxxxxxxx| 国产三级精品视频| 日本不卡在线视频| 色综合色综合色综合色综合色综合| 日韩一区二区电影网| 亚洲欧美一区二区三区久本道91| 日韩精品欧美精品| 色婷婷久久久久swag精品 | 久久精品国产久精国产| 一本久久a久久免费精品不卡| 日韩片之四级片| 亚洲综合av网| 久久97超碰色| 欧美色大人视频| 成人欧美一区二区三区白人| 国产精品123| 亚洲欧洲av一区二区三区久久| 丝袜美腿成人在线| 精品国产91九色蝌蚪| 青青草国产精品97视觉盛宴| 久久久影视传媒| 轻轻草成人在线| 日韩亚洲欧美一区| 国精产品一区一区三区mba视频| 欧美日韩一区 二区 三区 久久精品| 欧美国产日韩在线观看| 成人午夜视频在线观看| 欧美mv和日韩mv的网站| 欧美性受xxxx| 日本一区二区久久| 国产福利视频一区二区三区| 欧美va亚洲va| 麻豆国产91在线播放| 三级一区在线视频先锋| 欧美三级日本三级少妇99| 天天色综合天天| 精品国产精品一区二区夜夜嗨| 久久国产精品一区二区| 国产亚洲美州欧州综合国| 福利一区二区在线观看| 国产精品入口麻豆原神| 99国产精品国产精品毛片| 亚洲日本在线天堂| 日韩女优视频免费观看| www.一区二区| 免费看欧美美女黄的网站| 久久久久久99精品| 欧美影视一区二区三区| 国产成人免费在线观看不卡| 亚洲午夜私人影院| 国产校园另类小说区| 欧美一区二区三区不卡| 精品精品国产高清a毛片牛牛| 国产一区二区美女| 中文字幕不卡一区| 色婷婷久久综合| 国产成人综合网站| 日韩在线观看一区二区| 天堂影院一区二区| 91啦中文在线观看| 99精品久久99久久久久| 色伊人久久综合中文字幕| 亚洲主播在线观看| 欧美日韩电影在线播放| 日本中文一区二区三区| 欧美成人精品1314www| 精品伊人久久久久7777人| 日韩成人免费看| 欧洲一区在线电影| 久久久久久久久久久久久久久99| 中文av一区二区|