设置列默认值是否会损害数据库空间



这是一个简单的问题。我很好奇在 Rails+PostgreSQL 中为列设置默认值是否会花费额外的空间(而不是将默认值保留为 nil)。

我也很好奇这是否自然会导致结论,使用 rails(充满 nils)创建空记录是否占用与充满数据的行相同的空间。

我认为这在很大程度上取决于数据库实现,但我只对PostgreSQL数据库(9.1+)感兴趣。但是当我搜索特定于该的实现细节时,我迷路了。

设置默认值只是目录表pg_attributes中的一个属性。

但与NULL相比,表行中的实际值通常会花费额外的磁盘空间。 NULL值存储在称为"NULL 位图"的特殊结构中,并且每列需要一个位。因此,具有 NULL 值的行通常比具有(虚拟)值的行占用的磁盘空间更少。

它实际上更复杂。在这些相关答案中查找详细信息和链接:

  • 可为空的列在PostgreSQL中是否占用额外的空间?
  • 在PostgreSQL中计算和节省空间

最新更新