Rails4にて、中間テーブルにデータを挿入する方法を探しております。
つたない文章で大変申し訳ないのですが、ご回答をいただけると幸いです。
■対象テーブル
users(id, name)
jobs(id, name)
user_jobs(id, user_id, job_id)
■実現したい内容
user情報を編集する画面にて、
jobsテーブル内のデータの数だけチェックボックスを表示させ、
チェックされたjobデータの数だけ、
user_jobsテーブルにレコードを挿入したい
■備考
user情報を編集する画面では、
氏名(users.name)の更新と、
職種(user_jobs)レコードの新規作成、削除を目的としています
■参考にした記事
https://teratail.com/questions/19499
■ソース
モデル
Ruby
1class User < ActiveRecord::Base 2 authenticates_with_sorcery! 3 4 has_many :user_jobs 5 has_many :jobs, :through => :user_jobs 6 accepts_nested_attributes_for :user_jobs, allow_destroy: true 7end 8
Ruby
1class UserJob < ActiveRecord::Base 2 belongs_to :user 3 belongs_to :job 4end
コントローラー
Ruby
1class UsersController < ApplicationController 2 def edit 3 @user = current_user 4 @user.user_jobs.build 5 @job = Job.all 6 end 7 8 def params_user 9 params.require(:user).permit(:name) 10 end 11end
ビュー
haml
1 = form_for @user, url: settings_path, method: :put do |f| 2 %h2 3 設定 4 .form-body 5 .form-group 6 = f.label :name, "ユーザーID: tanaka tarou", class: "control-label" 7 = f.text_field :name, class: "form-control" 8 .form-group 9 = f.fields_for :user_jobs do |uj| 10 = uj.label :user_jobs, "職種", class: "control-label" 11 %p 12 -@job.each do |j| 13 = uj.check_box :job_ids, { multiple: true, checked: @user.user_jobs.include?(j.id), include_hidden: false }, j.id 14 = j.name 15ontrol" 16 = f.submit "送信する", class: "btn btn-success"``` 17 18■不明点 19 20・ストロングパラメーターの設定方法 21・ビューのfield_for部分の書き方 22 23■補足 24Web上のソースを色々と参考にさせていただいた結果、 25収集のつかない状態となっております。 26お見苦しいソースコードとなってしまい、大変申し訳ございません。
回答1件
あなたの回答
tips
プレビュー