我在使用 BTREE 索引或 HASH 索引之间进行辩论。
从理论上讲,使用 HASH 索引有什么好处?
什么时候应该选择它们,更重要的是,为什么?
我读过哈希索引对点查询很有用,但是为什么呢?
我已经知道 BTREE 索引最适合范围查询,因为您可以通过从左到右轻松遍历叶节点。
您没有提到特定的 DBMS,所以这个答案非常通用。
正确执行的哈希索引应该在一次提取中达到点查询的答案。B-Tree 将使用类似 lg_B(n) 二级存储访问,其中 B 是近似的分支因子,n 是条目数。缓存和合理的节点大小可能会将其保持在几次提取,但对于哈希索引仍然是两倍。此外,每个 B-Tree 访问都有与其关联的非平凡计算,以便遍历每个节点中的子索引(类似于每个节点的 lg_2(B) 数据比较操作)。哈希索引的计算时间通常非常有限(哈希计算和少量数据比较操作 - 希望是一次)。对于基于 B-Tree 的索引,在每个节点内进行搜索的计算时间通常很重要。
在挑选方面,如果
如果您有任何类型的范围查询和/或想要在一组可预先确定的列上排序结果,B-Tree 系列会更好。