`

MySQL索引的Index method中btree和hash的区别

 
阅读更多

在MySQL中,大多数索引(如 PRIMARY KEY,UNIQUE,INDEX和FULLTEXT)都是在BTREE中存储,但使用memory引擎可以选择BTREE索引或者HASH索引,两种不同类型的索引各自有其不同的使用范围。

Hash 索引结构的特殊性,其检索效率非常高,索引的检索可以一次定位,不像B-Tree 索引需要从根节点到枝节点,最后才能访问到页节点这样多次的IO访问,所以 Hash 索引的查询效率要远高于 B-Tree 索引。

可能很多人又有疑问了,既然 Hash 索引的效率要比 B-Tree 高很多,为什么大家不都用 Hash 索引而还要使用 B-Tree 索引呢?任何事物都是有两面性的,Hash 索引也一样,虽然 Hash 索引效率高,但是 Hash 索引本身由于其特殊性也带来了很多限制和弊端,主要有以下这些。

(1)Hash 索引仅仅能满足”=”,”IN”和”<=>”查询,不能使用范围查询。

由于 Hash 索引比较的是进行 Hash 运算之后的 Hash 值,所以它只能用于等值的过滤,不能用于基于范围的过滤,因为经过相应的 Hash 算法处理之后的 Hash 值的大小关系,并不能保证和Hash运算前完全一样。

(2)Hash 索引无法被用来避免数据的排序操作。

由于 Hash 索引中存放的是经过 Hash 计算之后的 Hash 值,而且Hash值的大小关系并不一定和 Hash 运算前的键值完全一样,所以数据库无法利用索引的数据来避免任何排序运算;

(3)Hash 索引不能利用部分索引键查询。

对于组合索引,Hash 索引在计算 Hash 值的时候是组合索引键合并后再一起计算 Hash 值,而不是单独计算 Hash 值,所以通过组合索引的前面一个或几个索引键进行查询的时候,Hash 索引也无法被利用。

(4)Hash 索引在任何时候都不能避免表扫描。

前面已经知道,Hash 索引是将索引键通过 Hash 运算之后,将 Hash运算结果的 Hash 值和所对应的行指针信息存放于一个 Hash 表中,由于不同索引键存在相同 Hash 值,所以即使取满足某个 Hash 键值的数据的记录条数,也无法从 Hash 索引中直接完成查询,还是要通过访问表中的实际数据进行相应的比较,并得到相应的结果。

(5)Hash 索引遇到大量Hash值相等的情况后性能并不一定就会比B-Tree索引高。

对于选择性比较低的索引键,如果创建 Hash 索引,那么将会存在大量记录指针信息存于同一个 Hash 值相关联。这样要定位某一条记录时就会非常麻烦,会浪费多次表数据的访问,而造成整体性能低下。

 

 

载录:

http://www.java-zone.org/?p=1190

分享到:
评论

相关推荐

    Mysql中的Btree与Hash索引比较

    MySQL中的Btree与Hash索引是两种常见的索引类型,每种都有其特定的适用场景和优缺点。这里我们将深入探讨这两种索引的特征以及它们在不同查询操作下的表现。 首先,Btree(B-Tree)索引是MySQL中最常用的索引结构,...

    索引类型FULLTEXT,HASH,BTREE,RTREE,索引优化1

    本文将围绕MySQL数据库中常见的三种索引类型——FULLTEXT、HASH和BTREE——进行深入探讨,并简要提及RTREE索引。我们会分析它们的原理、存储结构、优缺点以及如何在实际应用中进行选择和优化。 首先,我们来看BTREE...

    MySQL 索引最佳实践

    - **B树索引(BTREE索引)**:这是MySQL中最常见的索引类型,通常用于大多数存储引擎。 - **R树索引(RTREE索引)**:仅限于MyISAM存储引擎,主要用于地理信息系统(GIS)应用。 - **哈希索引(HASH索引)**:在...

    mysql 索引与执行计划

    MySQL中的索引也有类似的设计,例如BTREE索引。每个节点包含了主键ID,当通过主键ID查询数据时,首先会查询索引库以快速定位到具体的数据记录。 ##### 1.1.2 索引的分类 在MySQL中,索引可以根据不同的标准进行...

    MYSQL索引知识

    MySQL中的索引主要有两种存储类型:BTREE(B树)和HASH。 1. **什么是索引及建立索引的原因**: 索引是一种数据结构,它为数据库表中的列提供快速访问路径。当查询某个列中特定值的行时,MySQL不再需要从头到尾...

    btree索引.txt

    这里提到了BTree索引和Bitmap索引的区别。通常情况下,BTree索引不存储NULL值,而Bitmap索引则可以处理NULL值。这意味着如果某个字段经常出现NULL值,使用Bitmap索引可能更为合适。但是,在提供的表结构中,并没有...

    MySQL数据库索引优化

    在MySQL中,InnoDB和MyISAM存储引擎都支持BTree索引。BTree索引适合使用在等值查询和范围查询的场景。 Hash索引基于哈希表实现,它只适用于等值比较查询,例如在WHERE条件中使用等号进行单个值查询。与BTree索引...

    MySQL索引背后的数据结构及算法原理

    本文主要聚焦于BTree索引,这是MySQL中最常见的一种索引类型。 BTree(B+Tree)是一种自平衡的多路搜索树,广泛应用于数据库和文件系统中。它的特点是所有叶子节点在同一层,且每个节点可以有多个子节点,这使得...

    mysql索引介绍学习

    * 按索引方法划分:BTREE索引、HASH索引 * 按索引列数划分:单列索引、组合索引 * 按作用划分:覆盖索引、前缀索引等 MySQL的存储模型: * 连接管理:客户端跟数据库建立连接的过程,MySQL需要负责认证、管理连接...

    MySQL Hash索引和B-Tree索引的区别

    MySQL中的索引是提高查询效率的关键工具,其中两种常见的索引类型是Hash索引和B-Tree索引。这两种索引各有特点,适用于不同的查询场景。 首先,Hash索引以其高效的查找性能脱颖而出。Hash索引的工作原理是通过索引...

    MySQL 创建索引(Create Index)的方法和语法结构及例子

    FULLTEXT|SPATIAL] INDEX index_name [index_type] ON tbl_name (index_col_name,…) [index_type] index_col_name: col_name [(length)] [ASC | DESC] index_type: USING {BTREE | HASH | RTREE} 代码如下: — 创建...

    查看mySQL数据库索引

    - `index_type`: 索引的类型,如BTREE、HASH等。 - `comment`: 关于索引的注释。 - `index_comment`: 索引的用户定义注释。 #### 四、检查MySQL索引是否生效 为了确保索引能够正常工作并提高查询效率,我们需要...

    072401MySQL索引2

    InnoDB的BTREE是聚簇索引,数据和索引是存储在一起的,提高了检索效率。每张表只有一个聚簇索引,其他辅助索引都指向它,因此非聚簇索引的效率相对较低。 2. **HASH索引**:仅在Memory存储引擎中支持。它基于哈希...

    Mysql索引优化解决方案.doc

    "Mysql索引优化解决方案" MySQL索引是帮助MySQL高效获取数据的数据结构。MySQL在存储数据之外,还维护着满足特定查找...因此,在实际应用中需要合理地使用索引,选择合适的索引类型和索引结构,以达到最好的查询性能。

    第9章MySQL索引.docx

    另外,还有其他类型的索引,如哈希(HASH)索引和B树(BTREE)索引。哈希索引基于哈希函数,能实现快速的一次性定位,但通常只适用于等值查询,而不支持范围查询。而B树索引则是一种平衡多路搜索树,它可以按特定...

    mysql索引笔记1

    本文将深入探讨MySQL中的索引及其相关知识点。 首先,我们来了解索引的优点和缺点。索引如同书籍的目录,能够快速定位到数据,提高查询效率,减少磁盘I/O操作。同时,基于索引的排序也能降低CPU的消耗。然而,索引...

    Oracle-Btree索引.pptx

    Oracle-Btree索引,索引的ppt

Global site tag (gtag.js) - Google Analytics