• 应使用版本控制工具记录 schema.rb (或 structure.sql )的变化。

  • 应使用 rake db:scheme:load 而不是 rake db:migrate 来初始化空数据库。

  • 应在迁移文件中设置默认值,而不是在应用层面设置。

    1. # 差——在应用中设置默认值
    2. def amount
    3. self[:amount] or 0
    4. end

    虽然许多 Rails 开发者建议在 Rails 中强制使用表的默认值,但这会使数据受到许多应用 bug 的影响,因而导致应用极其难以维护。考虑到大多数有一定规模的 Rails 应用都与其它应用共享数据库,保持应用的数据完整性几乎是不可能的。

  • 务必使用外键约束。在 Rails 4.2 中,ActiveRecord 本身已经支持外键约束。

  • 书写建设性的迁移(添加表或列)时,应使用 change 方法而不是 updown 方法。

    1. # 老式写法
    2. class AddNameToPeople < ActiveRecord::Migration
    3. def up
    4. add_column :people, :name, :string
    5. end
    6. def down
    7. remove_column :people, :name
    8. end
    9. end
    10. # 新式写法(更好)
    11. class AddNameToPeople < ActiveRecord::Migration
    12. def change
    13. add_column :people, :name, :string
    14. end
    15. end
  • 不要在迁移中使用模型类。由于模型的变化,模型类也一直处在变化当中,过去运行正常的迁移可能不知什么时候就不能正常进行了。