当前位置:  开发笔记 > 数据库 > 正文

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

如何解决《是否可以在Rails迁移中使用外部SQL文件?》经验,为你挑选了1个好方法。

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

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

我怎样才能做到这一点?它甚至可能吗?



1> Mike Trpcic..:

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

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

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

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

rake db:rollback


ActiveRecord :: Base.establish_connection ActiveRecord :: Base.connection.execute(sql)
推荐阅读
yzh148448
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有