这是一个快速的问题。我很好奇在 Rails+PostgreSQL 中为列设置默认值是否会花费额外的空间(与将默认值保留为 nil 相比)。
我也很好奇,这是否会自然而然地导致得出结论,使用 rails(充满 nils)创建空记录是否占用与充满数据的行相同的空间。
我想这在很大程度上取决于数据库的实现,但我只对 PostgreSQL 数据库 (9.1+) 感兴趣。但是,当我在搜索特定于此的实现细节时,我迷路了。
最佳答案
设置默认值只是目录表 pg_attributes
中的一个属性。
但与 NULL
相比,表行中的实际值通常需要额外的磁盘空间。 NULL
值存储在称为“NULL 位图”的特殊结构中,并且每列需要一个位。因此,具有 NULL
值的行通常比具有(虚拟)值的行占用更少的磁盘空间。
其实更复杂。在这些相关答案中查找详细信息和链接:
关于ruby-on-rails - 设置列默认值是否会损害数据库空间?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22188119/