##前提・実現したいこと
デプロイ後の本番環境において、商品詳細画面に遷移し確認ボタンを押したい。
##発生している問題・エラーメッセージ
中間テーブルを使用した確認機能をローカル環境で実装、デプロイ後の本番環境においてエラー発生しました。
特定の商品の詳細画面に遷移すると確認ボタン(よくあるいいねボタンみたいな感じです)があり、クリックするとそのユーザーidと今見ている商品のidが中間テーブルに保存されます。
デプロイ後、商品詳細画面に遷移する際にエラーが発生。
##該当のソースコード、試したこと
中間テーブルを作成したので% heroku run rails db:migrate実行
その後% git push heroku master実行
ターミナルにて
Warning: the running version of Bundler (2.1.4) is older than the version that created the lockfile (2.2.11). We suggest you to upgrade to the version that created the lockfile by running `gem install bundler:2.2.11`.
% bundle -vで確認
Bundler version 2.1.4
% gem install bundler:2.2.11を実行
Fetching bundler-2.2.11.gem Successfully installed bundler-2.2.11 Parsing documentation for bundler-2.2.11 Installing ri documentation for bundler-2.2.11 Done installing documentation for bundler after 2 seconds 1 gem installed
% bundle -vで確認
Bundler version 2.2.11
なんかここでも% heroku run rails db:migrate
そしてもう一度% git push heroku master
やはりエラーが出る
今度は以下のエラー発見
ActiveRecord::StatementInvalid (Mysql2::Error: Table 'heroku_0bba6186d23d973.local_confirmations' doesn't exist):
中間テーブルのlocal_confirmationsが作られていない?
% heroku run rails db:migrateしたのに?
以降何度も% heroku run rails db:migrateと% heroku run rails db:migrate繰り返すが何も変わらず
助けてください!
##以下追記
% heroku run rails db:migrate:statusで確認したところ
up 20210325051648 Devise create users up 20210327010709 Create items up 20210327134502 Create active storage tablesactive storage up 20210330093735 Create web confirmations up 20210401080732 Create local confirmations
と出て全てupされております。
中間テーブルのlocal confirmationsが存在しupされているのに、なぜ存在しないと出るのでしょうか??
エラーはこんな感じです。
2021-04-03T06:25:07.432233+00:00 app[web.1]: I, [2021-04-03T06:25:07.432133 #4] INFO -- : [7c01129e-a9ed-4af5-88a5-a3d741bb3188] Processing by ItemsController#show as HTML 2021-04-03T06:25:07.432366+00:00 app[web.1]: I, [2021-04-03T06:25:07.432291 #4] INFO -- : [7c01129e-a9ed-4af5-88a5-a3d741bb3188] Parameters: {"id"=>"14"} 2021-04-03T06:25:07.590924+00:00 app[web.1]: D, [2021-04-03T06:25:07.590733 #4] DEBUG -- : [7c01129e-a9ed-4af5-88a5-a3d741bb3188] (8.2ms) SET NAMES utf8, @@SESSION.sql_mode = CONCAT(CONCAT(@@sql_mode, ',STRICT_ALL_TABLES'), ',NO_AUTO_VALUE_ON_ZERO'), @@SESSION.sql_auto_is_null = 0, @@SESSION.wait_timeout = 2147483 2021-04-03T06:25:07.602666+00:00 app[web.1]: D, [2021-04-03T06:25:07.602506 #4] DEBUG -- : [7c01129e-a9ed-4af5-88a5-a3d741bb3188] Item Load (6.5ms) SELECT `items`.* FROM `items` WHERE `items`.`id` = 14 LIMIT 1 2021-04-03T06:25:07.611217+00:00 app[web.1]: I, [2021-04-03T06:25:07.611079 #4] INFO -- : [7c01129e-a9ed-4af5-88a5-a3d741bb3188] Completed 500 Internal Server Error in 179ms (ActiveRecord: 21.9ms | Allocations: 794) 2021-04-03T06:25:07.612531+00:00 app[web.1]: F, [2021-04-03T06:25:07.612441 #4] FATAL -- : [7c01129e-a9ed-4af5-88a5-a3d741bb3188] 2021-04-03T06:25:07.612532+00:00 app[web.1]: [7c01129e-a9ed-4af5-88a5-a3d741bb3188] ActiveRecord::StatementInvalid (Mysql2::Error: Table 'heroku_0bba6186d23d973.local_confirmations' doesn't exist): 2021-04-03T06:25:07.612534+00:00 app[web.1]: [7c01129e-a9ed-4af5-88a5-a3d741bb3188] 2021-04-03T06:25:07.612534+00:00 app[web.1]: [7c01129e-a9ed-4af5-88a5-a3d741bb3188] app/controllers/items_controller.rb:25:in `show'
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。