3

「enrollment_app」という名前の Rails アプリがあります。これは、データベース内のすべてのテーブルを初期化し、MySQL シード ファイルでデータを入力します。アプリをビルドし、いくつかの移行を追加して、アプリを Heroku にプッシュしました。ただし、Heroku は Postgres を使用しているため、MySQL データベースを Heroku と互換性を持たせる方法が必要なので、ClearDB アドオンを使用しています。

アプリを開こうとすると、次のメッセージが表示されます。

Application Error
An error occurred in the application and your page could not be served. Please try again in a few moments.

If you are the application owner, check your logs for details.

そのため、ログを確認したところ、次のエラーが表示されました。

PG::UndefinedTable: ERROR:  relation "enrollments" does not exist

このチュートリアルに従っていますが、上記のエラーが発生しているため、ClearDB をローカルの MySQL DB のように見せる方法がわかりません。rake db:seedMySQL シード ファイルとrake db:migrate本番用の ClearDB データベースを同等にするにはどうすればよいですか?

更新 - Gemfile:

source 'https://rubygems.org'

gem 'rails', '4.2.1'
gem 'mysql2'
gem 'sass-rails', '~> 5.0'
gem 'uglifier', '>= 1.3.0'
gem 'coffee-rails', '~> 4.1.0'
gem 'jquery-rails'
gem 'turbolinks'
gem 'jbuilder', '~> 2.0'
gem 'sdoc', '~> 0.4.0', group: :doc
gem 'bootstrap-sass', '~> 3.3.5'
gem 'bootswatch-rails'
gem 'ransack'
gem 'jquery-turbolinks'
gem 'kaminari'
gem 'bootstrap-kaminari-views'
gem 'jquery-ui-rails'
gem 'espinita'
gem 'mysqltopostgres', git: "https://github.com/maxlapshin/mysql2postgres.git"

group :development, :test do
  gem 'byebug'
  gem 'web-console', '~> 2.0'
  gem 'spring'
  gem 'rspec-rails'
  gem 'launchy'
  gem 'pry'
  gem 'pry-nav'
  gem 'shoulda-matchers'
  gem 'factory_girl_rails'
  gem 'capybara'
  gem 'newrelic_rpm'
  gem 'poltergeist'
  gem 'database_cleaner'
end

group :production do
  gem 'rails_12factor'
end
4

1 に答える 1

3

これは ClearDB 自体の問題ではありません。PostgreSQL のデフォルトから完全に切り離されていないようです。私はチェックします:

  • pgあなたのGemfileで定義されていますか? そうであってはなりません。代わりにmysql2存在することを確認してください。
  • このアプリ用の Heroku ClearDB アドオンをインストールし、それをアプリが使用する既定のデータベースにしましたか? Heroku Postgres データベースをアンインストールしましたか? 完全な手順については、こちらを参照してください。

Heroku アプリが ClearDB データベースに正しく接続できたら、問題なくデータベース自体をセットアップできるはずです。

heroku run rake db:create
heroku run rake db:migrate
heroku run rake db:seed
于 2015-08-02T13:06:32.767 に答える