Mysql中的Btree与Hash索引比较

2019-01-05 09:58:36丽君

Hash 索引特征

Hash类型的索引有一些区别于以上所述的特征:

1.它们只能用于对等比较,例如=和<=>操作符(但是快很多)。它们不能被用于像<这样的范围查询条件。假如系统只需要使用像“键值对”的这样的存储结构,尽量使用hash类型索引。
2.优化器不能用hash索引来为ORDER BY操作符加速。(这类索引不能被用于搜索下一个次序的值)
3.mysql不能判断出两个值之间有多少条数据(这需要使用范围查询操作符来决定使用哪个索引)。假如你将一个MyISAM表转为一个依靠hash索引的MEMORY表,可能会影响一些语句(的性能)。
4.只有完整的键才能被用于搜索一行数据。(假如用B-tree索引,任何一个键的片段都可以用于查找。我觉得可能意味着带通配符LIKE操作符会不起作用)。

后记

顺便记录一下在使用mysql过程中碰到的一些问题:

有时候使用脚本迁移数据时会碰到乱码的问题,即使将表字符集设置成utf8也无济于事,这个时候在执行sql之前加一句set names utf8即可。

您可能感兴趣的文章:

mysql 数据库中索引原理分析说明MySQL索引背后的数据结构及算法原理详解mysql 添加索引 mysql 如何创建索引MySQL索引类型总结和使用技巧以及注意事项MySQL查看、创建和删除索引的方法MySQL 创建索引(Create Index)的方法和语法结构及例子MySQL 主键与索引的联系与区别分析Mysql索引会失效的几种情况分析基于mysql全文索引的深入理解Mysql使用索引的正确方法及索引原理详解