mysql引擎支持的索引_Mysql 在InnoDB引擎下支持hash索引吗?

场景

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

html

be87eab75de8d14415b54b4599c6be32.png

乍一看,不少人的第一反应是,这不是支持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;

11e1ce97ddb5d36721e906f0cdca410f.png

对应sql语句:

mysql

ALTER TABLE oauth.auth_userADD 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

a12a6bbc43010450f1d81788501e45b3.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;

ca5111296ef19b78075431cfac5130a1.png

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

分析:

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

d23726af9fcc707c2ed04d1f65e2c474.png从上面的图中能够得知,InnoDB和MyISAM只支持BTree索引。

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

性能

f50cf2a36e1fbe23db892dcd09545be6.png

能够发现InnoDB支持的全部特性,其中对Hash  index特征的支持描述是:

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

翻译过来:

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

那么什么是Adaptive Hash Index呢?

05ce08339ae74875e64691b6b8f72a32.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存储引擎.姜承尧.扫描版】也提到了这点

3cb11a9f681ae50d5798a8f82ae3b1f1.png

总结:

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

多看,多思,多实践,多记录,多交流,老万教你吊打面试官。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值