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

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

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

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

Ruby on Rails

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

Q&A

解決済

1回答

368閲覧

ベストアンサー機能で外部キーが保存されない。

keitarou1954

総合スコア1

Ruby

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

Ruby on Rails

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

0グッド

0クリップ

投稿2021/04/14 06:29

編集2021/04/14 06:33

困っていること

現在railsでQ&Aサイトの作成を行っています。
ベストアンサーに関するデータの保存のためにbestsテーブルの作成を行い、質問詳細ページの回答一覧からlink_toでベストアンサーにするためのパラメーターを受け渡し、外部キーの情報を保存しようと考えていました。
しかし特にエラー画面はでませんが、DBに外部キーの情報が保存されておりませんでした。どうにかデータの保存を行いたいためアドバイスを頂けたら幸いです。

ソースコード

↓ルーティング

rails

1省略 2 3root to: "questions#index" 4 resources :questions do 5 resources :answers, only: [:new, :create] do 6 resources :bests, only: :create 7 end 8 collection do 9 get 'search' 10 end 11 end 12 resources :users, only: :show

↓モデル

rails

1class User < ApplicationRecord 2 has_many :questions 3 has_many :answers 4 has_many :bests 5end 6 7class Question < ApplicationRecord 8 belongs_to :user 9 has_many :answers, dependent: :destroy 10 has_one :best, dependent: :destroy 11end 12 13class Answer < ApplicationRecord 14 belongs_to :user 15 belongs_to :question 16 has_one :best, dependent: :destroy 17end 18 19class Best < ApplicationRecord 20 belongs_to :user 21 belongs_to :question 22 belongs_to :answer 23 validates :question_id, uniqueness: { scope: :user_id } 24end 25

↓コントローラー

rails

1class BestsController < ApplicationController 2 def create 3 @best = Best.new( 4 user_id: current_user.id, 5 question_id: params[:question_id], 6 answer_id: params[:answer_id] 7 ) 8 @best.save 9 redirect_to root_path 10 end 11end 12

↓ビュー

rails

1<%= link_to "ベストアンサーにする", question_answer_bests_path(@question.user.id, answer.user.id), method: :post %>

試したこと

binding.pryで確認したところ@bestにはそれぞれのidがパラメーターで送られていましたがidやcreated_at,update_atがnilになっていたため調べるとこれはデータ保存時に更新されるとのことでした。
またparamsで確認するとpermitted: falseと記載がされていたためストロングパラメーターを使用する必要があるのかと考えたので試しにストロングパラメーターで書いてみました。

↓ターミナル

2: def create 3: @best = Best.new( 4: user_id: current_user.id, 5: question_id: params[:question_id], 6: answer_id: params[:answer_id] 7: ) 8: # @best = Best.new(best_params) => 9: binding.pry 10: @best.save 11: end [1] pry(#<BestsController>)> params => <ActionController::Parameters {"_method"=>"post", "authenticity_token"=>"9Y5qvJ4rKA8gk6cz/hYbPwjfr8I8OM7/EPHeHPJE50GJ4gZlqggQoYlqqoC2LQPbefhWtQDfC1TLTesTZD0Khw==", "controller"=>"bests", "action"=>"create", "question_id"=>"49", "answer_id"=>"52"} permitted: false> [2] pry(#<BestsController>)> @best => #<Best:0x00007fc87b57ab70 id: nil, user_id: 49, question_id: 49, answer_id: 52, created_at: nil, updated_at: nil>

↓試しにストロングパラメーターで受けてみる。

rails

1class BestsController < ApplicationController 2 def create 3 # @best = Best.new( 4 # user_id: current_user.id, 5 # question_id: params[:question_id], 6 # answer_id: params[:answer_id] 7 # ) 8 @best = Best.new(best_params) 9 @best.save 10 redirect_to root_path 11 end 12 13 14 def best_params 15 params.require(:best).permit().merge(user_id: current_user.id, question_id: params[:question_id],answer_id: params[:answer_id]) 16 end 17end 18 19

しかし上記ではパラメータが空ですとエラーが出てしましました。
やはり外部キーだけ保存するにはこのような記述ではいけないと思い調べましたが結論には至りませんでした。
どのように外部キーだけの情報を保存すればよいのかアドバイスを頂けたら幸いです。

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

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

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

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

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

guest

回答1

0

自己解決

先程確認したところlinkでパラメーターを送る際にidが@question.user.id, answer.user.idとなっていることに気づき@question.id, answer.idに修正して保存されるようになりました。

投稿2021/04/15 06:32

keitarou1954

総合スコア1

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問