【发布时间】:2012-09-20 17:59:02
【问题描述】:
在使用 ActiveRecord 运行应用程序时从表中删除列会导致错误,因为 ActiveRecord 会缓存列名。
其他版本的 ActiveRecord 的解决方法是覆盖模型中的 #columns 方法并在迁移之前过滤掉不推荐使用的列名(基本上 - 对 AR 隐藏这些列)。这是因为所有与列名相关的方法都基于#columns 调用
在 ActiveRecord 3.1 中,表结构的缓存被移至 ConnectionPool,并且所有与列名相关的值(例如 coluumns_hash)都被独立缓存(3.2 使用 ModelSchema.columns 使其再次工作)
在 ActiveRecord 3.1 中是否有任何方法(除了对具体适配器的深入破解)来实现安全的列删除?
【问题讨论】:
-
为什么不首先摆脱使用列的代码并部署它有特定的原因吗?然后,您可以在后续迁移中删除该列。
-
当你例如保存记录时,AR 会发出一条 SQL 语句,显式设置所有列值。因此,您的代码是否使用列并不重要 - 在所有列下方都使用
标签: ruby-on-rails ruby ruby-on-rails-3 activerecord