実現したいこと
現在、練習のため、Q&Aサイトを作成しています。Questionは、userができるようにし、answerは、特定の専門家の人が答えられるようにしています。
そこで、deviseでuserとは別にadviserのログイン機能を実装し、専門家専用の管理画面に飛び、そこで、questionに対するanswerを作成できるようにし、それが、questionの表示画面に表示できるようにしたいと考えています。
ご相談したい点
①どのようにDBを設計するか?
現在、以下のようにDBを設計しています。まず、この考え方で問題ないか、確認させてください。
- Userモデル
- Questionモデル
- Answerモデル
- Adviserモデル
関連は、以下のように考えています。
> Adviser model has_many :answers, dependent: :destroy > Answer model belongs_to :question, foreign_key: "question_id", optional: true belongs_to :adviser, foreign_key: "adviser_id" > Question model belongs_to :user, optional: true has_many :answers, dependent: :destroy > User model has_many :questions, dependent: :destroy
②どのようにコントローラーを作るべきか?
また、表示のイメージは以下のように考えています。
adviserの管理画面では、questions_controllerとanswers_controllerを作っていますが、
このように分けて書く方が良いのかどうか、結論が出ません。どのようにお考えになりますか?
上記の図で、A地点で、以下のようにコントローラーを書いています。
### questions_controller.rb class Adviser::QuestionsController < Adviser::ApplicationController skip_after_action :verify_authorized def index @questions = Question.all.paginate(:page => params[:page], :per_page => 20) end def show @question = Question.find(params[:id]) @answer = current_adviser.answers.build end end
### answers_controller.rb def create @answer = current_adviser.answers.build(answer_params) if @answer.save! flash[:notice] = "This answer is succesfully created." redirect_to adviser_answer_path(@answer) else flash[:alert] = "This answer failed to be created." render 'new' end end def answer_params params.require(:answer).permit(:content, :question_id, :adviser_id) end
③adviser管理画面でanswerに値を入れた場合、question_idをどう取得するか?
ですが、当たり前ですが、question_idが入っていません。
この場合、rails consoleで以下のように確認したところ、question_idの取得はできました。
@question = Question.find(Questionのid:1の値を取得).id @answer.question_id = @question
ただし、それを以下のようにしたところ、question_idの取得に失敗しました。
@question = Question.find(params[:id]).id @answer.question_id = @question
どのようにquestion_idを取得すれば良いのでしょうか?このように複数のモデルがある場合での
idの取得は非常に難しく、一気に取得できる方法はないものか、joinなどを試してみたのですが、
失敗しています。お知恵をお貸しください。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2018/03/12 14:23