将单个表推送到Heroku

Ave*_*ris 9 database deployment ruby-on-rails heroku

我知道heroku pg:push将整个数据库推送到Heroku 的命令.

现在我正在推出我的产品,我希望能够只推送一个包含本地收集信息的特定表,而不会覆盖现有表(例如用户).

是否有一个命令使我只能将特定的表推送到heroku?

Sim*_*tti 15

我的建议是直接使用pg_dumppsql命令使用PostgreSQL转储/恢复功能.

有了pg_dump你可以从你的本地数据库转储一个特定的表

$ pg_dump --data-only --table=products sourcedb > products.sql
Run Code Online (Sandbox Code Playgroud)

然后从配置中获取Heroku PostgreSQL连接字符串

$ heroku config | grep HEROKU_POSTGRESQL

# example
# postgres://user3123:passkja83kd8@ec2-117-21-174-214.compute-1.amazonaws.com:6212/db982398
Run Code Online (Sandbox Code Playgroud)

并使用从Heroku检索到的信息恢复远程数据库中的表.

$ psql -h ec2-117-21-174-214.compute-1.amazonaws.com -p 6212 -U user3123 db982398 < products.sql
Run Code Online (Sandbox Code Playgroud)

您将需要定制-p,-h-U参数,以及数据库名称.密码将提示psql.

您也可以使用pg_restore过滤转储并恢复表,但我个人更喜欢psql.

请注意,Heroku建议在多个文档中使用PostgreSQL工具,例如导入和导出大数据,或者提供的CLI命令不包括此问题中的特定情况.