加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

Do NULL占用postgresql索引中的空间吗?

发布时间:2020-12-13 16:07:39 所属栏目:百科 来源:网络整理
导读:虽然很容易记录N??ULL在行的 postgresql元组头中仅占用1位,但是在可空列的INDEX(不是元组,而是索引)中占用多少空间?索引中的1位与元组中的位相同,还是全列数据类型大小(EG:integer = 4字节)? 问题的上下文是我有一个postgresql表有3个引用列(EG:foo_id,b
虽然很容易记录N??ULL在行的 postgresql元组头中仅占用1位,但是在可空列的INDEX(不是元组,而是索引)中占用多少空间?索引中的1位与元组中的位相同,还是全列数据类型大小(EG:integer = 4字节)?

问题的上下文是我有一个postgresql表有3个引用列(EG:foo_id,bar_id和baz_id),对于任何行,这些列中只有一列会有一个值(其他2列将为NULL).但是,我需要索引所有3列.假设每列是一个整数(postgresql中为4个字节),每行应占用4个字节(对于非空列)加2位(对于2个空列).但是,如果我要为所有3列添加索引,则3个索引的存储将是12个字节(如果索引占用空值的全部4个字节)或者与元组中相同的4个字节2个位本身.

解决方法

btree访问例程使用PageGetItem()从索引中获取实际键.所以我认为btree索引页面使用与常规堆页面相同的存储方案(包括可空性掩码),它们只是在页面的“特殊”区域中有额外的导航信息来保存所有btree指针.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读