我正在Heroku上开发Ruby on Rails 3 web应用程序。如何清空数据库?
当前回答
检查你的heroku版本。我刚刚把我的更新到2.29.0,如下:
heroku --version
#=> heroku-gem/2.29.0 (x86_64-linux) ruby/1.9.3
现在你可以运行:
heroku pg:reset DATABASE --confirm YOUR_APP_NAME
然后创建你的数据库,并在一个命令中播种:
heroku run rake db:setup
现在重新启动并尝试应用程序:
heroku restart
heroku open
其他回答
假设你想重置你的PostgreSQL数据库并将其备份,使用:
heroku apps
在Heroku上列出你的申请。找到当前应用程序的名称(application_name)。然后运行
heroku config | grep POSTGRESQL
来获取数据库的名称。一个例子是
HEROKU_POSTGRESQL_WHITE_URL
最后,给定application_name和database_url,您应该运行
heroku pg:reset `database_url` --confirm `application_name`
heroku run rake db:migrate
heroku restart
Heroku现在已经弃用了——db选项,所以现在使用:
heroku pg:reset DATABASE_URL --confirm {the name of your app}
这有点令人困惑,因为你使用文字文本SHARED_DATABASE,但我已经写了{你的应用程序的名称}替换你的应用程序的名称。例如,如果你的应用程序被称为my_great_app,那么你使用:
heroku pg:reset DATABASE_URL --confirm my_great_app
我联系了Heroku的支持人员,他们确认这是最新宝石的bug(我正在使用Heroku -2.26.2)
查理——我们已经意识到‘heroku’宝石的这个问题了 正在努力解决它。 问题来了,如果你愿意的话 https://github.com/heroku/heroku/issues/356 降级到早期版本的“heroku”宝石应该会有所帮助。今天大部分时间我都在使用v2.25.0,没有任何问题。
使用以下命令降级:
gem uninstall heroku
gem install heroku --version 2.25.0
如果你已经安装了多个宝石,你可能会看到:
选择gem卸载: 1. heroku-2.25.0 2. heroku-2.26.2 3.所有版本
只需卸载#2并重新运行命令。快乐!
删除数据库:
$ heroku pg:reset SHARED_DATABASE --confirm NAME_OF_THE_APP
重新创建数据库:
$ heroku run rake db:migrate
为数据库播种:
$ heroku run rake db:seed
* *最后一步
$ heroku restart
我总是用一行程序“heroku pg:reset DATABASE”来做这件事。
推荐文章
- 理解:Rails的has_one/has_many的源选项
- 最好的打印散列的方法
- Rails:如何在Rails 4中引用CSS中的图像
- 使用pgadmin连接到heroku数据库
- 错误:无法使用rebase进行拉取:您有未分阶段的更改
- 在ROR迁移期间,将列类型从Date更改为DateTime
- ActiveRecord:大小vs计数
- 使用rvmrc或ruby版本文件设置RVM项目gemset ?
- 如何在控制器中使用Helper
- 如何用另一个键替换哈希键
- 添加一个CSS类<%= f.submit %>
- rmagick gem安装“无法找到Magick-config”
- 如何在Heroku上重新启动rails服务器?
- 如何使用Ruby on Rails进行HTTP请求?
- Heroku和GitHub:“项目无法检索,内部服务器错误”