5、数据库操作实用技巧与解决方案

数据库操作实用技巧与解决方案

1. 安全地在迁移中使用模型

1.1 问题描述

迁移是数据库模式的版本控制。在任何时候,都应该能够从源代码控制仓库中检出代码的最新版本,并从头开始重建数据库模式。有时在迁移中执行模型级操作很有用,但如何在迁移中使用模型而不导致历史数据库模式和代码之间的版本不匹配问题呢?

1.2 解决方案

为确保迁移始终拥有所需模型的兼容版本,可以在迁移内部创建本地命名空间的模型类。示例代码如下:

class AddPositionToProducts < ActiveRecord::Migration
  class Product < ActiveRecord::Base; end
  class SoftwareProduct < Product; end
  class CourseProduct < Product; end

  def self.up
    add_column :products, :position, :integer
    Product.reset_column_information
    # Set default list orders
    SoftwareProduct.all.each_with_index {|p, i| p.position = i; p.save! }
    CourseProduct.all.each_with_index {|p, i| p.position = i; p.save! }
  end

  def self.down
    remove_
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值