首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >哈希索引的用法是什么?

哈希索引的用法是什么?
EN

Stack Overflow用户
提问于 2021-02-11 03:20:38
回答 3查看 126关注 0票数 1

什么时候使用哈希索引?

我知道散列的理论:当通过散列搜索某个东西时,它在<>上是不可比较的,它只能相等或不相等。因此,相对于BTree不能执行分而治之的搜索,而是尽量精确。但是我不能理解它什么时候有用?

EN

回答 3

Stack Overflow用户

发布于 2021-02-11 03:25:18

哈希索引比b-tree索引更快--至少在理论上是这样。B树索引的搜索工作量为O(log )。散列索引更接近于恒定时间。

考虑到性能的提高,它们有时是有用的。通常不需要不等式和排序。

票数 3
EN

Stack Overflow用户

发布于 2021-02-11 10:07:57

在PostgreSQL中,btree索引对索引项的大小有一个硬性限制,大约是块大小的1/3。因此,如果您的表行中有0.00001%的值可能超过限制,那么就有问题了。散列索引避免了这一限制。

票数 0
EN

Stack Overflow用户

发布于 2021-07-20 13:52:51

散列索引对于相等查询非常有用,例如,当您在表中查找特定元素时(例如,WHERE id=1)。在这种情况下,理论上哈希索引更快。

另一方面,如果您还需要搜索元素的范围(例如,id>1和id<10),那么散列索引就没有任何用处了,您需要使用btree。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/66143615

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档