ruby-on-rails – 使用Rails迁移添加数据库列,并根据另一列填充它

我正在编写迁移以向表中添加列.列的值取决于另外两个现有列的值.最好/最快的方法是什么?
目前我有这个,但不确定它是否是最好的方式,因为组表可能非常大.
class AddColorToGroup < ActiveRecord::Migration
  def self.up
    add_column :groups,:color,:string
    Groups = Group.all.each do |g|
      c = "red" if g.is_active && is_live 
      c = "green" if g.is_active
      c = "orange"
      g.update_attribute(:type,c)
    end
  end

  def self.down

  end
end

解决方法

从这样的迁移中引用模型通常是个坏主意.问题是迁移按顺序运行并随着时间的推移更改数据库状态,但您的模型根本没有版本化.无法保证在编写迁移时存在的模型在将来仍然与迁移代码兼容.

例如,如果您将来更改is_active或is_live属性的行为,则此迁移可能会中断.对于新的模型代码,此旧迁移将首先运行,并且可能会失败.在这里的基本示例中,它可能不会出现,但是在添加字段并且验证无法运行之前,这已经让我在部署中烧毁了(我知道您的代码正在跳过验证,但通常这是一个问题).

我最喜欢的解决方案是使用纯sql进行所有这种迁移.看起来你已经考虑过了,所以我假设你已经知道该怎么做了.

一个选择,如果你有一些毛茸茸的业务逻辑或者只是希望代码看起来更像Railsy,那就是在迁移文件本身写入迁移时包含模型的基本版本.例如,您可以将此类放在迁移文件中:

class Group < ActiveRecord::Base
end

在您的情况下,仅此一点可能足以保证模型不会破坏.假设此时活动和活动是表中的布尔字段(因此将来会运行此迁移),您根本不需要任何更多代码.如果您有更复杂的业务逻辑,则可以将其包含在此特定于迁移的模型版本中.

您甚至可以考虑将模型中的整个方法复制到迁移版本中.如果你这样做,请记住,如果你的应用程序有可能在将来发生变化,你也不应该从那里引用你的应用程序中的任何外部模型或库.这包括gems甚至可能是一些核心Ruby / Rails类,因为gems中的API破坏性变化非常普遍(我正在看着你,Rails 3.0,3.1和3.2!).

相关文章

validates:conclusion,:presence=>true,:inclusion=>{...
一、redis集群搭建redis3.0以前,提供了Sentinel工具来监控各...
分享一下我老师大神的人工智能教程。零基础!通俗易懂!风趣...
上一篇博文 ruby传参之引用类型 里边定义了一个方法名 mo...
一编程与编程语言 什么是编程语言? 能够被计算机所识别的表...
Ruby类和对象Ruby是一种完美的面向对象编程语言。面向对象编...