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

标签 ruby-on-rails postgresql ruby-on-rails-3.2 postgresql-9.1 postgresql-9.2

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

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

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

最佳答案

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

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

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

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

相关文章:

ruby-on-rails - Launchy::ApplicationNotFoundError:

ruby-on-rails - 带有扭矩箱和 nginx 的 EC2 错误网关

python - 加载我的数据库页面(Flask/Heroku)时如何修复内部服务器错误?

ruby-on-rails - 让 find_by in rails 返回多个结果

php - 将时间存储在 VARCHAR 或秒 INT 中哪个是最好的方法?

ruby-on-rails - 样式化 Rails date_select 的日期字段

基于最后检索的记录的 SQL 分页

ruby-on-rails - capybara 断言没有从下拉列表中选择任何内容

javascript - 在 Rails 中为桌面和移动访问者分离 js 代码

ruby-on-rails - 我的 Ruby on Rails 应用程序中的内存泄漏