如何将heroku数据拉入本地SQLite3数据库? 遇到问题

我正在尝试从我的Rails应用程序进行本地备份,该应用程序部署到Heroku,并遇到问题。 我按照这里的说明操作: http : //docs.heroku.com/taps并安装了Taps。

我得到两种错误。 我在本地创建了一个SQLite数据库并尝试使用此命令提取数据:

(sudo)heroku db:pull sqlite://Users/username/folder/testbackup.db

要么

(sudo)heroku db:pull sqlite:// username:password@localhost/Users/username/folder/testbackup.db

但无论哪种方式,我得到这个:

无法连接数据库:Sequel :: DatabaseConnectionError – > SQLite3 :: CantOpenException:无法打开数据库:无法打开数据库文件

或者,我尝试让Taps在我的应用程序中自动检测开发数据库并重写它,尽管这不是我想要的。 然后我开始得到如下错误:

/opt/local/lib/ruby/site_ruby/1.8/rubygems.rb:777:in report_activate_error': RubyGem version error: sequel(3.15.0 not ~> 3.13.0) (Gem::LoadError) from /opt/local/lib/ruby/site_ruby/1.8/rubygems.rb:211:in激活’from /opt/local/lib/ruby/site_ruby/1.8/rubygems.rb:1056:in’gem’from/ Library / Ruby / Gems / 1.8 /gem/水龙头-0.3.10 /斌/架构:4

并最终

/System/Library/Frameworks/Ruby.framework/Versions/1.8/usr/lib/ruby/gems/1.8/gems/sqlite3-ruby-1.2.4/lib/sqlite3/errors.rb:62:in`check’: SQLite3 :: SQLException:PRIMARY KEY必须是唯一的(Sequel :: DatabaseError)

非常感谢,我开始尽快备份这些数据非常重要!

一些问题。 首先,你的续集连接字符串是错误的。 尝试

 heroku db:pull sqlite:///Users/username/folder/testbackup.db 

如果仍然出现exception,则可能是由于权限问题,因此请确保您可以写入该路径。

您的Rubygem版本错误是因为当前版本的水龙头需要续集3.13.0,并且您已经激活了3.15.0。 您需要使用3.13.0或者您需要编辑点击gem规范以使用3.15.0。

PRIMARY KEY必须是唯一的SQLiteexception。 没有完整的回溯和代码,很难猜出它为什么会发生。

使用SQLite3::SQLException: PRIMARY KEY must be unique (Sequel::DatabaseError)问题,我在拉动过程中将数据写入heroku数据库时看到了它。 如果我确保heroku上没有任何活动,似乎可以工作。 这是一种不科学的,可能纯属巧合的方法,但似乎对我有用。