微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

虽然很容易记录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指针.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐