通常会使用execute方法执行此操作,但由于语句的大小,我宁愿将它们保存在外部文件中并从迁移中引用它.
我怎样才能做到这一点?它甚至可能吗?
sql = "" source = File.new("./sql/procedures.sql","r") while (line = source.gets) sql << line end source.close execute sql
这很难看,但很有效.我强烈建议在迁移中保留存储过程/触发器以便轻松回滚.
如果您执行“外部文件”方法,则每次迁移需要维护两个额外的文件,一个用于添加所有内容,另一个用于在以下情况下放入:
rake db:rollback