mysql 索引中的USING BTREE 的意義


索引是在存儲引擎中實現的,因此每種存儲引擎的索引都不一定完全相同,並且每種存儲引擎也不一定支持所有索引類型。

根據存儲引擎定義每個表的最大索引數和最大索引長度。所有存儲引擎支持每個表至少16個索引,總索引長度至少為256字節。

大多數存儲引擎有更高的限制。MySQL中索引的存儲類型有兩種:BTREE和HASH,具體和表的存儲引擎相關;

MYISAM和InnoDB存儲引擎只支持BTREE索引;MEMORY和HEAP存儲引擎可以支持HASH和BTREE索引

         B-tree索引是數據庫中存取和查找文件(稱為記錄或鍵值)的一種方法.B-tree算法減少定位記錄時所經歷的中間過程,從而加快存取速度.

一個B-tree的典型例子就是硬盤中的結點.與內存相比,硬盤花成倍的時間來存取一個數據元素,這是硬盤的機械部件讀寫數據的速度遠遠趕不上純 電子媒體的內存.與一個結點兩個分支的二元樹相比,B-tree利用多個分支(稱為子樹)的結點,減少獲取記錄時所經歷的結點數,從而達到節省存取時間的 目的.

本文出自 “Linux生涯” 博客,請務必保留此出處http://lvzili.blog.51cto.com/1995527/564260


MySQL的BTREE索引和HASH索引

為什么要用索引?

  • 使用索引后減少了存儲引擎需要掃描的數據量,加快查詢速度
  • 索引可以把隨機I/O變為順序I/O
  • 索引可以幫助我們對所搜結果進行排序以避免使用磁盤臨時表

Mysql支持的索引類型:B-TREE索引與HASH索引,兩者有不同的使用場景,下面來簡單剖析下這兩者的區別。

CREATE TABLE act_info(
id BIGINT NOT NULL AUTO_INCREMENT,
act_id VARCHAR(50) NOT NULL COMMENT "活動id",
act_name VARCHAR(50) NOT NULL COMMENT "活動名稱",
act_date datetime NOT NULL,
PRIMARY KEY(id),
KEY idx_actid_name(act_id,act_name) USING BTREE
) ENGINE=INNODB DEFAULT CHARSET=UTF8 ROW_FORMAT=COMPACT COMMENT "活動記錄表";

 

B-TREE索引
B-TREE索引的特點

  • B-TREEB-TREE以B+樹結構存儲數據,大大加快了數據的查詢速度
  • B-TREE索引在范圍查找的SQL語句中更加適合(順序存儲)

 

B-TREE索引使用場景

  • 全值匹配的查詢SQL,如 where act_id= '1111_act'
  • 聯合索引匯中匹配到最左前綴查詢,如聯合索引 KEY idx_actid_name(act_id,act_name) USING BTREE,只要條件中使用到了聯合索引的第一列,就會用到該索引,但如果查詢使用到的是聯合索引的第二列act_name,該SQL則便無法使用到該聯合索引(注:覆蓋索引除外)
  • 匹配模糊查詢的前匹配,如where act_name like '11_act%'
  • 匹配范圍值的SQL查詢,如where act_date > '9865123547215'(not in和<>無法使用索引)
  • 覆蓋索引的SQL查詢,就是說select出來的字段都建立了索引

 

HASH索引
HASH的特點

  • Hash索引基於Hash表實現,只有查詢條件精確匹配Hash索引中的所有列才會用到hash索引
  • 存儲引擎會為Hash索引中的每一列都計算hash碼,Hash索引中存儲的即hash碼,所以每次讀取都會進行兩次查詢
  • Hash索引無法用於排序
  • Hash不適用於區分度小的列上,如性別字段

 

參考文章:https://dev.mysql.com/doc/refman/5.7/en/index-btree-hash.html
---------------------
作者:simonsfan
來源:CSDN
原文:https://blog.csdn.net/fanrenxiang/article/details/81781283
版權聲明:本文為博主原創文章,轉載請附上博文鏈接!


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM