gpt4 book ai didi

ruby-on-rails - 设置列默认值是否会损害数据库空间?

转载 作者:行者123 更新时间:2023-11-29 14:00:12 24 4
gpt4 key购买 nike

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

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

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

最佳答案

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

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

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

关于ruby-on-rails - 设置列默认值是否会损害数据库空间?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22188119/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com