是否可以在Rails迁移中使用外部SQL文件?

时间:2009-08-04 17:42:31

标签: sql ruby-on-rails migration

我必须创建一个Rails迁移,它创建了许多触发器和存储过程。

通常会使用execute方法执行此操作,但由于语句的大小,我宁愿将它们保存在外部文件中并从迁移中引用它。

我该怎么做?它甚至可能吗?

3 个答案:

答案 0 :(得分:10)

您可以将它们存储在文本文件中,然后通过File对象读取它们。

sql = ""
source = File.new("./sql/procedures.sql", "r")
while (line = source.gets)
  sql << line
end
source.close
execute sql

这很难看,但很有效。我强烈建议在迁移中保留存储过程/触发器以便于回滚。

如果您执行“外部文件”方法,则每次迁移需要维护两个额外的文件,一个用于添加所有内容,另一个用于在以下情况下放入:

rake db:rollback

答案 1 :(得分:2)

如果文件中只有一个语句,那么Mike的答案可以正常运行,但如果有更多语句(例如多个插入和更新),ActiveRecord将失败,因为默认情况下一次调用不支持多个语句

根据指示here,一种解决方案是修改ActiveRecord以支持多个语句。

其他解决方案是确保您的SQL文件每行只包含一个语句并使用类似

的循环
source = File.open "db/foo.sql", "r"
source.readlines.each do |line|
  line.strip!
  next if line.empty? # ensure that rows that contains newlines and nothing else does not get processed
  execute line
end
source.close

答案 2 :(得分:2)

我在需要的地方做了以下事情:

class RawSqlMigration < ActiveRecord::Migration
  def up
    execute File.read(File.expand_path('../../sql_migrations/file.sql', __FILE__))
  end
end