前置き
プログラミング学習を始めて日が浅いので見苦しいところがあるかもしれませんが、どうかご容赦頂ければ幸いです。ご指摘があれば直します。
前提・実現したいこと
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] [1m[36mUser Load (3.5ms)[0m [1m[34mSELECT `users`.* FROM `users` WHERE `users`.`id` = 1 ORDER BY `users`.`id` ASC LIMIT 1[0m 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なのも疑問です。
至らない点があるかと思いますが、ご教授よろしくお願いいたします。
回答1件
あなたの回答
tips
プレビュー