运维开发网

ruby-on-rails – 如果只有扩展名尚不存在,我该如何启用?

运维开发网 https://www.qedev.com 2020-05-31 14:05 出处:网络 作者:运维开发网整理
我正在使用Rails 4.2.7.我想创建一个启用扩展的迁移,但前提是我正在运行的主机环境中不存在该扩展.我创造了 class EnableUuidOsspExtension < ActiveRecord::Migration def change enable_extension 'uuid-ossp' end end 但是如果已经启用了扩展,我想禁止启用扩展.如何调整上述迁移才
我正在使用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
0

精彩评论

暂无评论...
验证码 换一张
取 消