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

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

在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 值相关联。这样要定位某一条记录时就会非常麻烦,会浪费多次表数据的访问,而造成整体性能低下。

转载于:https://my.oschina.net/henrydong/blog/161861

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/547379.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

软件研发测试工程师英文怎么说,软件测试工程师面试英文自我介绍

《软件测试工程师面试英文自我介绍》由会员分享&#xff0c;可在线阅读&#xff0c;更多相关《软件测试工程师面试英文自我介绍(4页珍藏版)》请在人人文库网上搜索。1、软件测试工程师面试英文自我介绍篇一、范文Im , Im twenty-six year old, I majored in E-business and wit…

JavaScript禁用页面刷新

JavaScript禁用页面刷新代码如下&#xff1a; //禁用F5刷新document.onkeydown function (){if (event.keyCode 116) {event.keyCode 0;event.cancelBubble true;return false;}}//禁止右键弹出菜单document.oncontextmenu function () {return false;} 添加完成之后&…

Linux (Ubuntu/CentOS) 添加用户并授予sudo的权限

添加用户 添加新用户username&#xff0c;创建的用户默认的登陆Shell是/bin/bash# useradd username 设置密码# passwd username 为该用户指定命令解释程序&#xff08;通常为/bin/bash&#xff09;# usermod -s /bin/bash csdn 如果是为了启动apache、nginx、mysql等服务&am…

Oracle 11g数据库管理与开发指南

为什么80%的码农都做不了架构师&#xff1f;>>> Oracle 11g数据库管理与开发指南 本书内容系统而全面&#xff0c;详细讲解了Oracle数据库的管理、开发、性能优化、以及PL/SQL 编程的相关知识&#xff0c;面面俱到&#xff1b;注重实战&#xff0c;为每个知识…

JS性能优化

下面是一些关于客户端JS性能的一些优化的小技巧&#xff1a; 1.关于JS的循环&#xff0c;循环是一种常用的流程控制。JS提供了三种循环&#xff1a;for(;;)、while()、for(in)。在这三种循环中 for(in)的效率最差&#xff0c;因为它需要查询Hash键&#xff0c;因此应尽量少用f…

跨考计算机教研室,跨考教研室专家:脱离题海沉浮 做到有效做题_跨考网

很多同学在考研数学复习时&#xff0c;只知道一味的做题&#xff0c;诚然做题是必须的&#xff0c;但是应该采取相应的规划&#xff0c;有思想、有计划的去做题。那么&#xff0c;如何做题能够有效高效的提升数学水准呢&#xff0c;这里跨考教育教研室李老师给大家几点建议。思…

Ubuntu下安装配置JDK1.7

1、下载JDK 对于下载方法&#xff0c;可以使用命令&#xff0c;也可以手动下载。本人采用手动下载jdk的方式。 下载jdk-7u7-linux-i586.tar.gz到Ubuntu桌面。 2、 将下载的文件移动到这个文件夹下面并进行解压 如果目标文件夹存在则跳过此步骤&#xff0c;否则输入如下命令…

山东省计算机春季高考大纲,2017年山东春季高考专业知识考试大纲.doc

2017年山东春季高考专业知识考试大纲土建类专业知识考试说明本专业知识考试说明以山东省教育厅制定的中等职业学校《建筑施工专业教学指导方案》为依据&#xff0c;结合山东省中等职业学校的教学实际编写&#xff0c;以省教育厅公布的中等职业学校教学用书目录为主要参考教材。…

SQL Server 跨网段(跨机房)复制

一.本文所涉及的内容&#xff08;Contents&#xff09; 本文所涉及的内容&#xff08;Contents&#xff09;背景&#xff08;Contexts&#xff09;解决方案&#xff08;Solution&#xff09;搭建过程&#xff08;Process&#xff09;注意事项&#xff08;Attention&#xff09;…

gcc编译C++程序

单个源文件生成可执行程序 下面是一个保存在文件 helloworld.cpp 中一个简单的 C 程序的代码&#xff1a; /* helloworld.cpp */ #include <iostream> int main(int argc,char *argv[]) { std::cout << "hello, world" << std::endl; return(…

Twitter Storm安装配置(Ubuntu系统)单机版

要使用storm首先要安装以下工具&#xff1a;JDK、Python、zookeeper、zeromq、jzmq、storm &#xff08;注&#xff1a;各个模块都是独立的&#xff0c;如果安装失败或者卡顿可以单独百度某个模块的安装&#xff0c;都是可以的。&#xff09; JDK1.7安装 参见上篇《Ubuntu下安…

活动目录应用篇一:使用windows server 2008 backup备份AD是的账户权限问题

使用windowsserver2008backup备份AD的时候&#xff0c;需要提供执行账户的权限在指定备份计划的时候需要logonasabatchjob权限的用户这个权限到哪里添加呢&#xff1f;这个需要在组策略中去添加&#xff1a;说到组策略&#xff0c;我们知道组策略分为本地组策略与域组策略本地组…

计算机中隐藏的文件找不到了怎么办,隐藏文件夹找不到了怎么办【图解】

在今天&#xff0c;越来越多的人利用电脑来办公。甚至有一些工作&#xff0c;已经与电脑密切相关了。电脑以其强大的功能辅助人们工作&#xff0c;但有时在操作过程中会碰到这样或那样的问题。这个时候人们就会叹其操作的复杂性。就好比如有时你隐藏了一个文件&#xff0c;可是…

CentOS6 配置 yum 阿里源

一、CentOS6停止维护更新日期2020年11月30日 二、2020年12月2日下架了包括官方所有的CentOS6源&#xff08;包括国内的镜像站&#xff09; 三、CentOS6也完成了它的历史使命 在生产的环境中依旧由很多CentOS6系统依然在坚持&#xff0c;那么可以采取挂载光盘或者使用centos-va…

使用ab进行页面的压力测试

ab是apache自带的一个很好用的压力测试工具&#xff0c;当安装完apache的时候&#xff0c;就可以在bin下面找到ab 参数说明及示例 我们可以模拟100个并发用户&#xff0c;对一个页面发送1000个请求 输入命令&#xff1a;ab -n1000 -c100 http://stone_w.cnblogs.com/ 其中-n代…

poj 3067

树状数组求逆序数的应用&#xff1a; JapanTime Limit: 1000MS Memory Limit: 65536KTotal Submissions: 17874 Accepted: 4819Description Japan plans to welcome the ACM ICPC World Finals and a lot of roads must be built for the venue. Japan is tall island with N c…

取消计算机触摸板,笔记本电脑触摸板,详细教您笔记本电脑触摸板怎么关闭

很多的笔记本的用户都习惯使用鼠标&#xff0c;主要是因为笔记本触摸板操作不太方便&#xff0c;没有鼠标操作灵活。反而是经常在电脑中打字等操作时容易误碰到笔记本触摸板&#xff0c;导致输入错误等等&#xff0c;因此很多朋友一般会关闭触摸板&#xff0c;可是笔记本触摸板…

OC学习笔记--基础篇

本文简要介绍了一些oc的基础类型&#xff0c;包括数组、字典、字符串、消息传递、类、对象、方法、属性、协议和转发&#xff0c;希望对你有帮助。 OC数据类型 打印—类似print NSlog("hello word");数组 NSMutableArray &#xff08;可变数组&#xff09;和 NSAr…

linux gcc编译下的文件读写操作

linux下的文件操作 所有目录 1.文件及文件系统的定义 2.linux文件的类型 3.linux文件的权限 4.文件操作 4.1 文件的创建 4.2 文件的打开及关闭 4.3 文件的读写操…

PL/SQL Developer中文版下载以及使用图解(绿色版)

下载地址&#xff1a;http://pan.baidu.com/s/1eQCTmkM 1、运行plsqldev.exe程序&#xff1b; 2、设置Oracle主目录名/OCI库地址&#xff0c;如图&#xff1a; 重新启动程序。 3、配置登陆信息&#xff0c;连接数据库&#xff0c;如图&#xff1a;