如何在不初始化Rails的情况下从schema.rb创建数据库?

时间:2013-02-23 00:19:41

标签: ruby-on-rails ruby

我正在尝试从schema.rb

创建所有表

我使用了命令:“rake db:schema:load”

然而,这失败了,因为在我的一个初始化器中,它引用了一个显然不存在的模型/表(因为数据库为空)

我可以注释掉这些行,然后运行schema:再次加载,但还有其他选择吗?

2 个答案:

答案 0 :(得分:39)

可能最快的方法是将有问题的初始化程序移动到应用程序之外的临时目录,然后运行架构加载。但是,如果这不起作用,或者由于某种原因不是一个选项,你总是可以通过创建一个简单的rails应用程序来解决这个问题:

  1. 创建新的rails应用:rails new (app)-fixer
  2. gemfile(除非有特定例外情况)复制到修复程序应用程序。
  3. database.yml配置复制到修复程序应用。
  4. 将您的schema.rb文件复制到修复程序应用程序。
  5. 根据您的应用需要执行所有相应的“捆绑安装”命令。
  6. 然后运行"rake db:drop db:create db:schema:load"
  7. 这将根据您当前的架构从头开始构建一个新数据库。

答案 1 :(得分:6)

您可以在初始化程序中添加对表存在的检查。

if TheModel.table_exists?
  // do something with the model
end