我正在使用Rails 4.2.7.我想创建一个启用扩展的迁移,但前提是我正在运行的主机环境中不存在该扩展.我创造了
class EnableuuidOsspExtension < ActiveRecord::Migration def change enable_extension 'uuid-ossp' end end
但是如果已经启用了扩展,我想禁止启用扩展.如何调整上述迁移才能实现此目的?这样做的动机是因为在我的本地机器上我必须运行它才能将它添加到PostGres,但是如果我迁移到Heroku,这个扩展可能已经到位,但是当我运行db迁移时我不想让事情崩溃脚本.
解决方法
有一个扩展方法返回一个扩展名数组,所以你可以做这样的事情:
def up enable_extension('uuid-ossp') unless extensions.include?('uuid-ossp') end def down disable_extension('uuid-ossp') if extensions.include?('uuid-ossp') end
您也可以在sql中手动执行此操作,您可以访问create extension if not exists
:
def up connection.execute('create extension if not exists "uuid-ossp"') end