虽然很容易记录NULL在行的
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个位本身.
解决方法
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。