微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

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

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

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

解决方法

您可以将它们存储在文本文件中,然后通过File对象读取它们.
sql = ""
source = File.new("./sql/procedures.sql","r")
while (line = source.gets)
  sql << line
end
source.close
execute sql

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

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

rake db:rollback

原文地址:https://www.jb51.cc/mssql/77488.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐