我必须创建一个Rails迁移,它会创建许多触发器和存储过程。是否可以在Rails迁移中使用外部SQL文件?
通常情况下,人们会使用execute
方法来做到这一点,但由于语句的大小,我宁愿将它们保存在外部文件中并从迁移中引用它。
我该怎么做?它甚至有可能吗?
我必须创建一个Rails迁移,它会创建许多触发器和存储过程。是否可以在Rails迁移中使用外部SQL文件?
通常情况下,人们会使用execute
方法来做到这一点,但由于语句的大小,我宁愿将它们保存在外部文件中并从迁移中引用它。
我该怎么做?它甚至有可能吗?
您可以将它们存储在文本文件中并通过File对象读取它们。
sql = ""
source = File.new("./sql/procedures.sql", "r")
while (line = source.gets)
sql << line
end
source.close
execute sql
这是丑陋的,但工程。我强烈建议保留迁移中的存储过程/触发器以便轻松回滚。
如果你做的“外部文件”的方法,你需要保持每迁移两个文件,一个是将所有的东西,一个是在下降的情况下的在:
rake db:rollback
如果文件中只有一条语句,Mike的答案没有问题,但如果有更多语句(例如多个插入和更新),ActiveRecord将会失败,因为它默认情况下不支持具有一个调用的多个语句。
一个解决方案是修改ActiveRecord以支持多条语句,如here指示。
其他的解决办法是,以确保您的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
我做了以下内容,我们需要:
class RawSqlMigration < ActiveRecord::Migration
def up
execute File.read(File.expand_path('../../sql_migrations/file.sql', __FILE__))
end
end
的ActiveRecord :: Base的.establish_connection ActiveRecord :: Base.connection.execute(sql) – drhenner 2012-08-23 19:22:48