mysql使用btree是什么_mysql 索引中的USING BTREE有什么用

本文深入探讨了数据库索引的两种主要类型——B-TREE和HASH。B-TREE索引以其B+树结构提供快速查询,特别适合范围查找和全值匹配查询。而HASH索引基于哈希表,适用于精确匹配查询,但不支持范围查询和排序。理解这两种索引的工作原理和适用场景对于优化数据库性能至关重要。
摘要由CSDN通过智能技术生成

创建索引时使用的索引方式,有btree和hash两种

CREATE [UNIQUE | FULLTEXT | SPATIAL] INDEXindex_name[index_type]

ONtbl_name (key_part,...)[index_option]

[algorithm_option | lock_option]...

key_part:col_name [(length)] [ASC | DESC]index_option:

KEY_BLOCK_SIZE[=]value|index_type| WITHPARSER parser_name| COMMENT 'string'index_type:

USING {BTREE|HASH}

algorithm_option:

ALGORITHM[=] {DEFAULT | INPLACE |COPY}

lock_option:

LOCK[=] {DEFAULT | NONE | SHARED | EXCLUSIVE}

一些存储引擎允许您在创建索引时指定索引类型。例如:

CREATE TABLE lookup (id INT) ENGINE =MEMORY;CREATE INDEX id_index ON lookup (id) USING BTREE;

B-TREE索引的特点

B-TREEB-TREE以B+树结构存储数据,大大加快了数据的查询速度

B-TREE索引在范围查找的SQL语句中更加适合(顺序存储)

B-TREE索引使用场景

全值匹配的查询SQL,如 where act_id= '1111_act'

联合索引汇中匹配到最左前缀查询,如联合索引 KEY idx_actid_name(act_id,act_name) USING BTREE,只要条件中使用到了联合索引的第一列,就会用到该索引,但如果查询使用到的是联合索引的第二列act_name,该SQL则便无法使用到该联合索引(注:覆盖索引除外)

匹配模糊查询的前匹配,如where act_name like '11_act%'

匹配范围值的SQL查询,如where act_date > '9865123547215'(not in和<>无法使用索引)

覆盖索引的SQL查询,就是说select出来的字段都建立了索引

HASH索引的特点

Hash索引基于Hash表实现,只有查询条件精确匹配Hash索引中的所有列才会用到hash索引

存储引擎会为Hash索引中的每一列都计算hash码,Hash索引中存储的即hash码,所以每次读取都会进行两次查询

Hash索引无法用于排序

Hash不适用于区分度小的列上

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值