这是一个简单的问题。我很好奇在 Rails+PostgreSQL 中为列设置默认值是否会花费额外的空间(而不是将默认值保留为 nil)。
我也很好奇这是否自然会导致结论,使用 rails(充满 nils)创建空记录是否占用与充满数据的行相同的空间。
我认为这在很大程度上取决于数据库实现,但我只对PostgreSQL数据库(9.1+)感兴趣。但是当我搜索特定于该的实现细节时,我迷路了。
设置默认值只是目录表pg_attributes
中的一个属性。
但与NULL
相比,表行中的实际值通常会花费额外的磁盘空间。 NULL
值存储在称为"NULL 位图"的特殊结构中,并且每列需要一个位。因此,具有 NULL
值的行通常比具有(虚拟)值的行占用的磁盘空间更少。
它实际上更复杂。在这些相关答案中查找详细信息和链接:
- 可为空的列在PostgreSQL中是否占用额外的空间?
- 在PostgreSQL中计算和节省空间