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

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

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

Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

Q&A

解決済

2回答

411閲覧

ruby on rails 複数レコードの保存方法について。

vowy

総合スコア13

Ruby on Rails 4

Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

0グッド

0クリップ

投稿2017/08/20 16:18

編集2017/08/20 23:44

質問があります。お助けください!

とある会社の年間目標計画みたいなのを作ってます。
今現在companyテーブルとyearly_planテーブルがあり、yearly_plansテーブルは(company_idカラム、年間目標カラム、売り上げ目標カラム、顧客満足度カラム、termカラム)の5つを持っています。
売り上げ目標カラムと顧客満足度カラムに関しては1期〜4期のタブを設けて一括で保存したいです。(termレコードには1~4のいずれかの数字が入ります。)
https://gyazo.com/3090b91c7e1d5c0b6a8a3433ecec2ecf
☝️こんな感じです。

まとめると、1つのビュー(app/views/yearly_plans/new.html.erb)から年間目標カラムは共通で、売り上げ目標カラムと顧客満足度カラムはそれぞれ1期〜4期に分ける。すなわち1つのformから4つのレコードを作る方法を知りたいです。

説明が下手くそですいません。よく分からない点等ありましたら質問お願いします。よろしくお願いいたします。

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

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

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

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

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

guest

回答2

0

yearly_plansテーブルは分割した方が良いと思います

  • yearly_plans(company_id、年間目標)
  • term_plans(yearly_plans_id, term, 顧客満足度)

yearly_plansの作成編集に合わせて一緒にterm_plansを作成編集するには、Nested Attributes/Nested model formsという機能が使えます。 これを見とけ、というリソースが見つからないので、Googleで検索してみてください。

投稿2017/08/21 01:39

suzukis

総合スコア1449

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

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

0

ベストアンサー

質問の通りの構造だとすると、company_id と年間目標と term を Primary Key とすることになりますが、年間目標は term が変わっても同一年度であれば変わらないのですから、重複してデータを持つことになります。これはデータの正規化が正しくできていないということです。
yearly_plan の他に、term_plan として別テーブルに分離しておくほうが良いと思います。

本題に戻りますが、ビューから登録・更新を受けるコントローラーの中で、データをもとに複数のレコードを new なり find して save するなりすればよいです。

投稿2017/08/21 00:07

tacsheaven

総合スコア13703

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.49%

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

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

質問する

関連した質問