使用ActiveRecord运行应用程序时从表中删除列会导致错误,因为ActiveRecord会缓存列名称。
其他版本的ActiveRecord的解决方法是覆盖模型中的#columns方法,并在迁移之前过滤掉已弃用的列名称(基本上 - 从AR隐藏这些列)。这很有效,因为所有与列名相关的方法都基于#columns调用
在ActiveRecord 3.1中,表结构的缓存被移动到ConnectionPool,所有与列名相关的值(例如coluumns_hash)都被独立缓存(3.2使用ModelSchema.columns使其再次工作)
ActiveRecord 3.1中是否有任何方法(除了深入破解具体适配器)以实现安全的列丢失?
答案 0 :(得分:3)
TST Media的Luke Ludwig提供了一个解决方案here。基本上它们“覆盖正在删除其列的类的ActiveRecord :: Base.columns方法。”
(适用于3.1以外的所有解决方案)
答案 1 :(得分:1)
如果您有多个应用程序服务器,以便您可以一次停用一个服务器而不停机,则以下内容将起作用: