场景
不少人可能在使用Navicat给表建立索引时会发现,索引方法中支持BTREE和HASH
html

乍一看,不少人的第一反应是,这不是支持hash索引吗?
实践
那么咱们来实践一下。java
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;

对应sql语句:
mysql
ALTER TABLE oauth.auth_user ADD INDEX index1(username) USING HASH COMMENT '测试hash索引';
保存成功,表的DML语句变为:web
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,
sql

可是表定义语句仍是没有变化,数据库
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;

发现主键索引和index1索引的index_type都是btree,说明建立的hash索引是没有生效的。
分析:
查一下mysql官方文档:https://dev.mysql.com/doc/refman/5.7/en/create-index.html,app

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

能够发现InnoDB支持的全部特性,其中对Hash index特征的支持描述是:
No (InnoDB utilizes hash indexes internally for its Adaptive Hash Index feature.)
翻译过来:
不支持(InnoDB在内部利用hash索引来实现其自适应hash索引特性)
那么什么是Adaptive Hash Index呢?

根据文件,不难发现,自适应索引是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存储引擎.姜承尧.扫描版】也提到了这点

总结:
Mysql InnoDB引擎不支持hash索引,可是在内存结构中有一个自适应hash索引,来提升查询性能。
多看,多思,多实践,多记录,多交流,老万教你吊打面试官。
更多精彩,关注我吧。
本文分享自微信公众号 - 跟着老万学java(douzhe_2019)。
若有侵权,请联系 support@oschina.cn 删除。
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一块儿分享。