首页 > 编程 > Ruby > 正文

Ruby on Rails迁移时的一些注意事项

2020-10-29 19:37:18
字体:
来源:转载
供稿:网友


    把 schema.rb 保存在版本管控之下。
    使用 rake db:scheme:load 取代 rake db:migrate 来初始化空的数据库。
    使用 rake db:test:prepare 来更新测试数据库的 schema。

    避免在表里设置缺省数据。使用模型层来取代。

  def amount   self[:amount] or 0  end

    然而 self[:attr_name] 的使用被视为相当常见的,你也可以考虑使用更罗嗦的(争议地可读性更高的) read_attribute 来取代:

    

def amount   read_attribute(:amount) or 0  end

    当编写建设性的迁移时(加入表或栏位),使用 Rails 3.1 的新方式来迁移 - 使用 change 方法取代 up 与 down 方法。

  

 # 过去的方式  class AddNameToPerson < ActiveRecord::Migration   def up    add_column :persons, :name, :string   end   def down    remove_column :person, :name   end  end  # 新的偏好方式  class AddNameToPerson < ActiveRecord::Migration   def change    add_column :persons, :name, :string   end  end

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表