我正在Heroku上开发Ruby on Rails 3 web应用程序。如何清空数据库?
当前回答
登录到您的DB使用 Heroku pg:psql,输入以下命令:
drop schema public cascade;
create schema public;
其他回答
要删除数据库,如果你使用SHARED_DATABASE_URL:
$ heroku pg:reset DATABASE_URL
现在重新创建一个没有任何内容的数据库:
$ heroku run rake db:migrate
用种子数据填充数据库:
$ heroku run rake db:seed
——或
你可以通过执行以下命令将最后两个(migrate & seed)合并为一个动作:
$ heroku run rake db:setup
编辑2014-04-18:rake db:setup不能与Rails 4一起工作,它失败了,提示不能创建数据库错误。
编辑2014-10-09:你可以在Rails 4中使用rake db:setup。它会给你一个cannot 't create database错误(因为数据库已经使用heroku pg:reset命令创建了)。但是它也会在错误消息之后加载数据库模式和种子。
您可以使用几乎任何rake命令来实现这一点,但也有例外。例如,db:reset不能通过heroku运行rake工作。你必须使用pg:reset来代替。
更多信息可以在Heroku的文档中找到:
运行Rake命令
重置Postgres DB
今天的命令
heroku pg:reset --db SHARED_DATABASE_URL
不为共享计划工作,我决定使用
heroku pg:reset SHARED_DATABASE
完整的答案是(对于有多个db的用户):
Heroku pg:info -输出
=== HEROKU_POSTGRESQL_RED <——这是DB 计划基本 可用状态
heroku pg:reset HEROKU_POSTGRESQL_RED——确认app_name
更多信息请访问:https://devcenter.heroku.com/articles/heroku-postgresql
水流。2017年的做法是:
heroku pg:reset DATABASE
https://devcenter.heroku.com/articles/heroku-postgresql#pg-reset
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上重新启动rails服务器?
- 如何使用Ruby on Rails进行HTTP请求?
- Heroku和GitHub:“项目无法检索,内部服务器错误”
- 如何关闭部署在Heroku上的应用程序?
- Rails—找不到JavaScript运行时?
- 最好的方法加载模块/类从lib文件夹在Rails 3?
- 'heroku'似乎不是一个git存储库
- 替换字符串中的单词- Ruby
- 防止Heroku空转的简单方法?
- Rails:当模型已经存在时,如何运行“Rails生成脚手架”?
- 如何运行单个RSpec测试?
- 分离REST JSON API服务器和客户端?
- 我如何在Ruby on Rails 3.1禁用资产管道(链轮)消息的日志记录?
- 如何清空Heroku数据库
- 没有匹配“/users/sign_out”的路由