数据库特定迁移代码

Stu*_*ssa 2 mysql migration postgresql ruby-on-rails rails-migrations

我正在创建一个需要在多个数据库下运行的应用程序.我目前在迁移中有一些代码,我只想在特定的数据库(postgresql和mysql)下运行.有什么方法可以设置吗?谢谢.

mu *_*ort 5

您的迁移可以访问数据库连接,connection并且连接有一个adapter_name方法,因此您可以询问它是什么类型的连接:

def self.up
    case connection.adapter_name
    when 'PostgreSQL'
        # Do PostgreSQL stuff
    when 'MySQL'
        # Do MySQL stuff
    else
        # Blow up and catch on fire. Or silently ignore it depending on your needs.
    end
end
Run Code Online (Sandbox Code Playgroud)

我不确定我的MySQL适配器名称是否正确,但技术是否合理,您可以自己轻松检查MySQL适配器名称.