首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >将Rails迁移转换为原始SQL

将Rails迁移转换为原始SQL
EN

Stack Overflow用户
提问于 2013-02-17 04:41:51
回答 2查看 3.3K关注 0票数 5

如何将此迁移转换为原始sql?或者我能改信吗?

代码语言:javascript
复制
class AddUnsubscribeTokenToUsers < ActiveRecord::Migration
  def self.up
    add_column :users, :unsubscribe_token, :string, :unique => true
    User.all.each do |user|
        user.unsubscribe_token = ActiveSupport::SecureRandom.hex(18)
    end
  end
  def self.down
    remove_column :users, :unsubscribe_token
  end
end
EN

回答 2

Stack Overflow用户

发布于 2013-02-17 06:16:41

你不能把单一的迁移转换成SQL,但是你可以让ActiveRecord用SQL而不是Ruby来输出你的模式。

代码语言:javascript
复制
# in config/application.rb

config.active_record.schema_format = :sql

这将在您的db/schema中提供SQL输出,而不是Ruby DSL。但是这两种格式都不会包含设置用户令牌的代码片段。

此外,在您的迁移中包含这样的DB修改代码也被认为是一个坏主意。例如,如果您删除或重命名模型会发生什么情况,当迁移运行时会失败。至少把它包装在模型的检查中。或者是begin/rescue/end

代码语言:javascript
复制
if defined? User
  User.all.each do |user|
    user.unsubscribe_token = ActiveSupport::SecureRandom.hex(18)
  end
end

代码语言:javascript
复制
begin
  User.all.each do |user|
    user.unsubscribe_token = ActiveSupport::SecureRandom.hex(18)
  end
rescue
end

最后,由于您在设置令牌后没有保存模型,因此该代码片段不会执行预期的操作,无论是使用update_attributes还是调用user.save

票数 3
EN

Stack Overflow用户

发布于 2015-02-06 21:48:07

我偶然发现了一个very nice article,描述了如何通过自定义的rake任务来实现这一点。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/14914892

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档