Mysql 的InnoDB引擎下支持hash索引吗?

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
云数据库 RDS MySQL Serverless,价值2615元额度,1个月
简介: Mysql 的InnoDB引擎下支持hash索引吗?

Mysql 的InnoDB引擎下支持hash索引吗?


什么,这个不是很明显支持的吗?还总是被面试官问到hash索引的btree索引有什么区别?


那么真的支持吗?



场景


很多人可能在使用Navicat给表创建索引时会发现,索引方法中支持BTREE和HASH


2.png



乍一看,很多人的第一反应是,这不是支持hash索引吗?


实践


那么我们来实践一下。

CREATE TABLE `auth_user` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `username` varchar(20) DEFAULT NULL COMMENT '用户名',
  `password` varchar(20) DEFAULT NULL COMMENT '密码',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8mb4;

3.png


对应sql语句:

ALTER TABLE oauth.auth_user
ADD INDEX index1(username) USING HASH COMMENT '测试hash索引';


保存成功,表的DML语句变为:

CREATE TABLE `auth_user` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `username` varchar(20) DEFAULT NULL COMMENT '用户名',
  `password` varchar(20) DEFAULT NULL COMMENT '密码',
  PRIMARY KEY (`id`),
  KEY `index1` (`username`) USING HASH COMMENT '测试hash索引'
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8mb4;

很多人可能会立刻说,这不是创建成功了吗?


我们继续,重新打开数据库连接,打开表设计,会发现index1索引的索引方法变成了btree,

4.png


但是表定义语句还是没有变化,

CREATE TABLE `auth_user` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `username` varchar(20) DEFAULT NULL COMMENT '用户名',
  `password` varchar(20) DEFAULT NULL COMMENT '密码',
  PRIMARY KEY (`id`),
  KEY `index1` (`username`) USING HASH COMMENT '测试hash索引'
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8mb4;

那么这时,索引index1到底是btree索引还是hash索引呢?

通过命令查看表auth上的索引信息

show index from auth_user;


5.png



发现主键索引和index1索引的index_type都是btree,说明创建的hash索引是没有生效的。



分析:

查一下mysql官方文档:https://dev.mysql.com/doc/refman/5.7/en/create-index.html


6.png


从上面的图中可以得知,InnoDB和MyISAM只支持BTree索引。



我们具体查一下InnoDB文档那一部分:https://dev.mysql.com/doc/refman/5.7/en/innodb-introduction.html


7.png



可以发现InnoDB支持的所有特性,其中对Hash index特征的支持描述是:

No (InnoDB utilizes hash indexes internally for its Adaptive Hash Index feature.)

翻译过来:

不支持(InnoDB在内部利用hash索引来实现其自适应hash索引特性)



那么什么是Adaptive Hash Index呢?


8.png




根据文件,不难发现,自适应索引是InnoDB引擎的内存结构中的一种特性。

对自适应hash索引的描述:

自适应hash索引特性使InnoDB能够在具有适当的工作负载和足够的缓冲池内存的系统上执行更像内存中的数据库,而不牺牲事务特性或可靠性。

总的来说就是提高了查询性能。



那么怎样启动自适应hash索引的特性呢?

14.15 InnoDB Startup Options and System Variables
System variables that are true or false can be enabled at server startup by naming them, or disabled by using a --skip- prefix. For example, to enable or disable the InnoDB adaptive hash index, you can use --innodb-adaptive-hash-index or --skip-innodb-adaptive-hash-index on the command line, or innodb_adaptive_hash_index or skip_innodb_adaptive_hash_index in an option file.


翻译过来就是可以在启动命令中,加上--innodb-adaptive-hash-index就可以开启InnoDB 自适应索引的特性了。


其实【MySQL技术内幕InnoDB存储引擎.姜承尧.扫描版】也提到了这点


9.png



总结:


Mysql InnoDB引擎不支持hash索引,但是在内存结构中有一个自适应hash索引,来提高查询性能。


相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
3天前
|
SQL 存储 关系型数据库
MySQL索引及事务
MySQL索引及事务
14 2
|
3天前
|
存储 SQL 关系型数据库
完蛋!😱 我被MySQL索引失效包围了!
完蛋!😱 我被MySQL索引失效包围了!
|
3天前
|
SQL 存储 关系型数据库
MySQL的3种索引合并优化⭐️or到底能不能用索引?
MySQL的3种索引合并优化⭐️or到底能不能用索引?
|
3天前
|
存储 SQL 关系型数据库
MySQL索引,看这一篇就够了!
MySQL索引,看这一篇就够了!
|
4天前
|
Java 关系型数据库 MySQL
MySQL 索引事务
MySQL 索引事务
12 0
|
4天前
|
存储 SQL 关系型数据库
MySQL 底层数据结构 聚簇索引以及二级索引 Explain的使用
MySQL 底层数据结构 聚簇索引以及二级索引 Explain的使用
19 0
|
4天前
|
自然语言处理 关系型数据库 MySQL
一文明白MySQL索引的用法及好处
一文明白MySQL索引的用法及好处
14 0
|
4天前
|
运维 负载均衡 关系型数据库
MySQL高可用解决方案演进:从主从复制到InnoDB Cluster架构
MySQL高可用解决方案演进:从主从复制到InnoDB Cluster架构
|
5天前
|
存储 SQL 关系型数据库
MySQL的优化利器⭐️索引条件下推,千万数据下性能提升273%🚀
以小白的视角探究MySQL索引条件下推ICP的优化,其中包括server层与存储引擎层如何交互、索引、回表、ICP等内容
MySQL的优化利器⭐️索引条件下推,千万数据下性能提升273%🚀
|
5天前
|
存储 SQL 关系型数据库
mysql中MyISAM和InnoDB的区别是什么
mysql中MyISAM和InnoDB的区别是什么
12 0