怎么使用PostgreSQL中Hash索引
发表于:2025-11-07 作者:千家信息网编辑
千家信息网最后更新 2025年11月07日,本篇内容介绍了"怎么使用PostgreSQL中Hash索引"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所
千家信息网最后更新 2025年11月07日怎么使用PostgreSQL中Hash索引
本篇内容介绍了"怎么使用PostgreSQL中Hash索引"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
逻辑结构
可以把Hash Index理解为一个Hash Table,每个Hash bucket存储根据Hash Function计算得到的对应的索引条目,为了节省空间,Hash索引条目只存储Hash Code(即Hash Value) + TID而不存储Hash Key(即索引键值),扫描索引后还必须读取相应的数据表行,因此Index Only Scan不适用于Hash Index.
testdb=# drop table if exists t_idx1;DROP TABLEtestdb=# create table t_idx1(id int,c1 varchar(20));CREATE TABLEtestdb=# create index idx_t_idx1_id on t_idx1 using hash(id);CREATE INDEXtestdb=# insert into t_idx1 select generate_series(1,100000);INSERT 0 100000testdb=# analyze t_idx1;ANALYZEtestdb=# explain verbose select * from t_idx1 where id = 1; QUERY PLAN ------------------------------------------------------------------------------------ Index Scan using idx_t_idx1_id on public.t_idx1 (cost=0.00..8.02 rows=1 width=62) Output: id, c1 Index Cond: (t_idx1.id = 1)(3 rows)testdb=# -- 不能实现Index Only Scantestdb=# explain verbose select id from t_idx1 where id = 100; QUERY PLAN ----------------------------------------------------------------------------------- Index Scan using idx_t_idx1_id on public.t_idx1 (cost=0.00..8.02 rows=1 width=4) Output: id Index Cond: (t_idx1.id = 100)(3 rows)
而普通的B-Tree索引是可以Index Only Scan的:
testdb=# create table t_idx2(id int,c1 varchar(20));CREATE TABLEtestdb=# insert into t_idx2 select generate_series(1,100000);INSERT 0 100000testdb=# create index idx_t_idx2_id on t_idx2 using btree(id);CREATE INDEXtestdb=# analyze t_idx2;ANALYZEtestdb=# explain verbose select id from t_idx2 where id = 100; QUERY PLAN ---------------------------------------------------------------------------------------- Index Only Scan using idx_t_idx2_id on public.t_idx2 (cost=0.29..8.31 rows=1 width=4) Output: id Index Cond: (t_idx2.id = 100)(3 rows)
有四种页面,分别是Meta page,Bucket Page,Overflow page和Bitmap page.
| 页面类型 | 说明 |
|---|---|
| Meta page | page number zero, which contains information on what is inside the index. |
| Bucket pages | main pages of the index, which store data as «hash code - TID» pairs. |
| Overflow pages | structured the same way as bucket pages and used when one page is insufficient for a bucket |
| Bitmap pages | which keep track of overflow pages that are currently clear and can be reused for other buckets |
使用pageinspect插件可查看index中的相关信息
testdb=# select hash_page_type(get_raw_page('idx_t_idx1_id',0)); hash_page_type ---------------- metapage(1 row)testdb=# select hash_page_type(get_raw_page('idx_t_idx1_id',1)); hash_page_type ---------------- bucket(1 row)testdb=# \xExpanded display is on.testdb=# select * from hash_page_stats(get_raw_page('idx_t_idx1_id',1));-[ RECORD 1 ]---+-----------live_items | 189dead_items | 0page_size | 8192free_size | 4368hasho_prevblkno | 256hasho_nextblkno | 4294967295hasho_bucket | 0hasho_flag | 2hasho_page_id | 65408testdb=# select * from hash_page_stats(get_raw_page('idx_t_idx1_id',2));-[ RECORD 1 ]---+-----------live_items | 201dead_items | 0page_size | 8192free_size | 4128hasho_prevblkno | 257hasho_nextblkno | 4294967295hasho_bucket | 1hasho_flag | 2hasho_page_id | 65408"怎么使用PostgreSQL中Hash索引"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注网站,小编将为大家输出更多高质量的实用文章!
索引
存储
内容
更多
条目
知识
页面
实用
普通
不适
学有所成
接下来
信息
困境
实际
情况
插件
数据
数据表
文章
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
安卓软件开发ppt下载
中兴r5300g4服务器管理口
中学生阅读软件开发
迁安电子网络技术答疑解惑
银行app服务器在哪
湖北网络安全节目
八维网络安全
什么级别的数据库
数据库 码和属性
什么网易服务器最好
国际蛋白质结构数据库
网络安全方向有哪些部门
数据库 数据文件
形势与政策网络安全论文题目
软件开发费 几个点税
怎样开启sqlite数据库
提升网络安全的金点子
jbpm4.4 数据库
信息网络安全评价方法
珠海酒店软件开发报价
嘉兴数字化智慧校园软件开发
崇明区新能源软件开发服务
Jpa数据库链接不释放
浙江发展网络技术咨询哪家强
新基建风口下网络安全
内蒙古数据库安全箱价目表
赛迪集团网络安全所蒲松涛
深圳运维管理软件开发解决方案
南昌数据库培训哪里有
网络安全 经费保障