我正在Heroku上开发Ruby on Rails 3 web应用程序。如何清空数据库?


当前回答

水流。2017年的做法是:

heroku pg:reset DATABASE

https://devcenter.heroku.com/articles/heroku-postgresql#pg-reset

其他回答

登录到您的DB使用 Heroku pg:psql,输入以下命令:

drop schema public cascade;
create schema public;

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版本。我刚刚把我的更新到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

这对我来说很管用。 1.清晰的db。

heroku pg:reset --app YOUR_APP

运行后,你必须再次输入你的应用程序名称来确认。

2.迁移数据库重新创建。

heroku run rake db:migrate  --app YOUR_APP

3.将种子数据添加到数据库。

heroku run rake db:seed --app YOUR_APP

假设你想重置你的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