質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Heroku

HerokuはHeroku社が開発と運営を行っているPaaSの名称です。RubyやNode.js、Python、そしてJVMベース(Java、Scala、Clojureなど)の複数のプログラミング言語をサポートしている。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Q&A

解決済

1回答

1195閲覧

デプロイ後のエラーについて

keso

総合スコア1

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Heroku

HerokuはHeroku社が開発と運営を行っているPaaSの名称です。RubyやNode.js、Python、そしてJVMベース(Java、Scala、Clojureなど)の複数のプログラミング言語をサポートしている。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

0グッド

0クリップ

投稿2020/05/27 09:25

編集2020/05/27 13:25

前置き
プログラミング学習を始めて日が浅いので見苦しいところがあるかもしれませんが、どうかご容赦頂ければ幸いです。ご指摘があれば直します。

前提・実現したいこと

railsを使い三択クイズアプリを作成中。ローカル環境ではうまくいくのだがデプロイしたところでエラーがでる。herokuでデプロイしたあと出るようになったエラーを直したい。
herokuのログを見るとunknown attribute 'user_id'のエラーが気になった。

発生している問題・エラーメッセージ

herokuのログより抜粋
フォームを利用して問題を作成しているときに起きるエラーです。

2020-05-27T08:46:52.015634+00:00 app[web.1]: [0458eb39-5f2e-48c5-9fdf-95daad705629] Started POST "/questions" for 126.140.162.74 at 2020-05-27 08:46:52 +0000 2020-05-27T08:46:52.017426+00:00 app[web.1]: [0458eb39-5f2e-48c5-9fdf-95daad705629] Processing by QuestionsController#create as HTML 2020-05-27T08:46:52.017503+00:00 app[web.1]: [0458eb39-5f2e-48c5-9fdf-95daad705629] Parameters: {"utf8"=>"✓", "authenticity_token"=>"VE4epB2iWbBUTkJxlzWqdEe64Nheevs3O5kqGeYhrIhDvDp68sgzSI8wkXIRCOmlrpJ20cLyZW+9J2g4H8oNaw==", "question"=>{"title"=>"あ", "questions"=>"あs", "choice1"=>"da", "choice2"=>"w", "choice3"=>"w", "correct"=>"だ"}, "commit"=>"問題を作る"} 2020-05-27T08:46:52.031188+00:00 app[web.1]: [0458eb39-5f2e-48c5-9fdf-95daad705629] User Load (3.5ms) SELECT `users`.* FROM `users` WHERE `users`.`id` = 1 ORDER BY `users`.`id` ASC LIMIT 1 2020-05-27T08:46:52.033220+00:00 app[web.1]: [0458eb39-5f2e-48c5-9fdf-95daad705629] Completed 500 Internal Server Error in 15ms (ActiveRecord: 3.5ms) 2020-05-27T08:46:52.038142+00:00 app[web.1]: [0458eb39-5f2e-48c5-9fdf-95daad705629] 2020-05-27T08:46:52.048835+00:00 app[web.1]: [0458eb39-5f2e-48c5-9fdf-95daad705629] ActiveModel::UnknownAttributeError (unknown attribute 'user_id' for Question.): 2020-05-27T08:46:52.049205+00:00 app[web.1]: [0458eb39-5f2e-48c5-9fdf-95daad705629] 2020-05-27T08:46:52.052215+00:00 app[web.1]: [0458eb39-5f2e-48c5-9fdf-95daad705629] app/controllers/questions_controller.rb:11:in `create' 2020-05-27T08:46:52.054060+00:00 heroku[router]: at=info method=POST path="/questions" host=kesoquestion.herokuapp.com request_id=0458eb39-5f2e-48c5-9fdf-95daad705629 fwd="126.140.162.74" dyno=web.1 connect=1ms service=47ms status=500 bytes=1827 protocol=https

該当のソースコード

ruby

1question.rb(modelsファイル) 2 3class Question < ApplicationRecord 4 5#association 6 belongs_to :user 7 has_many :answers 8 9 #validation 10 validates_presence_of :user_id 11 12 def user_answer(user_id) 13 Answer.find_by(user_id: user_id, question_id: id) 14 end 15end

ruby

1user.rb(modelsファイル) 2 3class User < ApplicationRecord 4 # Include default devise modules. Others available are: 5 # :confirmable, :lockable, :timeoutable, :trackable and :omniauthable 6 devise :database_authenticatable, :registerable, 7 :recoverable, :rememberable, :validatable 8 9 #association 10 has_many :questions 11 has_many :answers 12 has_many :answered_questions, through: :answers, source: :question 13 14end

ruby

1question_controller 2 3 def new 4 @question = Question.new 5 end 6 7 def create 8 Question.create(create_params) 9 redirect_to :root and return 10 end 11 12 private 13 def create_params 14 params.require(:question).permit(:questions,:title,:choice1,:choice2,:choice3,:correct).merge(user_id: current_user.id) 15 end

ruby

1new.html.erb(viewファイル) 2 3<%= form_for(@question) do |f| %> 4 <div class="qs_make">クイズタイトル<br> 5 <%= f.text_area :title,:size=>"60x1", placeholder: "例:railsコマンド" %><br> 6 問題<br> 7 <%= f.text_area :questions,:size=>"60x5", placeholder: "例:サーバーを立ち上げるコマンドは?" %><br> 8 選択肢A<br> 9 <%= f.text_area :choice1,:size=>"60x1", placeholder: "例:rails routes" %><br> 10 選択肢B<br> 11 <%= f.text_area :choice2,:size=>"60x1", placeholder: "例:rails g" %><br> 12 選択肢C<br> 13 <%= f.text_area :choice3,:size=>"60x1", placeholder: "例:rails s" %><br> 14 正解<br> 15 <%= f.text_area :correct,:size=>"60x1", placeholder: "例:rails s" %><br> 16 <%= f.submit "問題を作る" %>

試したこと

1.ローカル環境で同じようにフォームを利用した問題作成を行ったところエラーはでなかった。そのときの内容を以下に添付します。

ruby

1Started POST "/questions" for 126.140.162.74 at 2020-05-27 08:39:18 +0000 2Cannot render console from 126.140.162.74! Allowed networks: 127.0.0.1, ::1, 127.0.0.0/127.255.255.255 3Processing by QuestionsController#create as HTML 4 Parameters: {"utf8"=>"✓", "authenticity_token"=>"mTqTLkFQUkms10wu8fqKvqinEbu2OT7mm5J13V/WGMEZEoezFHWGvoExkY9DHwGalgOIHPr/+2whlaQmulJahg==", "question"=>{"title"=>"s", "questions"=>"d", "choice1"=>"d", "choice2"=>"ds", "choice3"=>"dss", "correct"=>"ss"}, "commit"=>"問題を作る"} 5 User Load (0.3ms) SELECT `users`.* FROM `users` WHERE `users`.`id` = 1 ORDER BY `users`.`id` ASC LIMIT 1 6/home/ec2-user/.rvm/gems/ruby-2.5.1/gems/activerecord-5.2.4.1/lib/active_record/log_subscriber.rb:98 7 (0.1ms) BEGIN 8 ↳ app/controllers/questions_controller.rb:11 9 User Load (0.2ms) SELECT `users`.* FROM `users` WHERE `users`.`id` = 1 LIMIT 1 10 ↳ app/controllers/questions_controller.rb:11 11 Question Create (0.2ms) INSERT INTO `questions` (`questions`, `choice1`, `choice2`, `choice3`, `created_at`, `updated_at`, `title`, `correct`, `user_id`) VALUES ('d', 'd', 'ds', 'dss', '2020-05-27 08:39:18', '2020-05-27 08:39:18', 's', 'ss', 1) 12 ↳ app/controllers/questions_controller.rb:11 13 (1.9ms) COMMIT 14 ↳ app/controllers/questions_controller.rb:11 15Redirected to https://1bd90c4b2e0a4403a5c1c79dac4ded86.vfs.cloud9.ap-northeast-1.amazonaws.com/ 16Completed 302 Found in 12ms (ActiveRecord: 2.7ms)

2.git statusを行った→すべてコミットできていた
3.git push heroku masterを行った→問題なかった。
4.unknown attribute 'user_id'とあったので、以下のサイトを参考に外部キーを試してみた→エラーは消えなかった。
参考サイトhttps://qiita.com/yoshizaki_kkgk/items/e58624129adc4f4917d8
5.一度デプロイしたアプリを削除して再度デプロイした。→エラーは消えなかった。

補足情報(FW/ツールのバージョンなど)

ruby 2.5.1p57
Rails 5.2.4.2
mysql使用
AWS利用
heroku利用

ローカル環境でうまくいっていたことがデプロイ後にできなくなる記事は見かけるのですが、参考にしてもうまく解決できずにいます。このような場合commitかpushでミスがあると考えるべきなのでしょうか?herokuのログの中に「FROM users WHERE users.id = 1」とあるのにuser_idがunkownなのも疑問です。

至らない点があるかと思いますが、ご教授よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

hoshi-takanori

2020/05/27 10:23

データベースは何をお使いですか?
keso

2020/05/27 13:23

コメントありがとうございます。 DBはmysqlを使用しています。
HTMLdoc

2020/05/28 08:12

heroku run rails db:migrateは試しましたか?
keso

2020/05/28 08:31

コメントありがとうございます。 はい。試しましたが状況は変わらずとなっております。 念のためそちらのコマンドを入力したあとの反応をこちらに記載しておきます ーーーーーーーーーーーーーーーーーーーーーーーー Running rails db:migrate on ⬢ kesoquestion... up, run.5320 (Free) (2.3ms) 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 (1.7ms) SELECT GET_LOCK('2476752383876115345', 0) (1.9ms) SELECT `schema_migrations`.`version` FROM `schema_migrations` ORDER BY `schema_migrations`.`version` ASC ActiveRecord::InternalMetadata Load (2.1ms) SELECT `ar_internal_metadata`.* FROM `ar_internal_metadata` WHERE `ar_internal_metadata`.`key` = 'environment' LIMIT 1 (1.9ms) BEGIN (2.0ms) COMMIT (1.7ms) SELECT RELEASE_LOCK('2476752383876115345') ーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーー
guest

回答1

0

自己解決

なんとかエラーを解決することができました。
お騒がせしました。

quesitonテーブルにuser_idを追加するmigrationファイルにミスがありました。
開発環境ではmigrationファイルではなくてphpadminから解決していたのでミスを放置したままになっていました。
migrationファイルを下記名をして再度デプロイしたところエラーが解消できました。

コメントくださったかたありがとうございました。
皆さんの貴重な時間を使わせてしまって申し訳ございません。

投稿2020/05/28 16:07

keso

総合スコア1

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問