ruby-on-rails – 将单个表推送到Heroku

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

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

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

解决方法

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

使用pg_dump,您可以从本地数据库转储特定的表

$pg_dump --data-only --table=products sourcedb > products.sql

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

$heroku config | grep HEROKU_POSTGRESQL

# example
# postgres://user3123:passkja83kd8@ec2-117-21-174-214.compute-1.amazonaws.com:6212/db982398

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

$psql -h ec2-117-21-174-214.compute-1.amazonaws.com -p 6212 -U user3123 db982398 < products.sql

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

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

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

相关文章

validates:conclusion,:presence=>true,:inclusion=>{...
一、redis集群搭建redis3.0以前,提供了Sentinel工具来监控各...
分享一下我老师大神的人工智能教程。零基础!通俗易懂!风趣...
上一篇博文 ruby传参之引用类型 里边定义了一个方法名 mo...
一编程与编程语言 什么是编程语言? 能够被计算机所识别的表...
Ruby类和对象Ruby是一种完美的面向对象编程语言。面向对象编...