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

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

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

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

Q&A

解決済

2回答

668閲覧

Rails form_with 複数モデルを一つのフォームで登録できない

07290729

総合スコア15

Ruby on Rails 5

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

0グッド

0クリップ

投稿2018/01/09 12:19

編集2018/01/10 15:45

以下のようなコードを用いて
複数モデル(1対多)の登録を一つのフォームで行おうと思っているのですが
disk情報を入力する欄が画面に出力されません。。。
(入力フォーム自体は出ているのですが、、、)

イメージ説明

そもそも画面にフォームが出てこないので
モデルの関連付けの部分以前かと思いますが
どこが間違っているのかご教授いただければ幸いです。

※ちなみに以下のページを参照して試行錯誤しています。
https://techracho.bpsinc.jp/hachi8833/2017_05_01/39502
http://iroiroblog.com/rails-form-multi-model/

#_former

<%= form_with(model: targetserver, local: true) do |form| %> <% if targetserver.errors.any? %> <div id="error_explanation"> <h2><%= pluralize(targetserver.errors.count, "error") %> prohibited this targetserver from being saved:</h2> <ul> <% targetserver.errors.full_messages.each do |message| %> <li><%= message %></li> <% end %> </ul> </div> <% end %> <div class="field"> <%= form.label :hostname %> <%= form.text_field :hostname, id: :targetserver_hostname %> </div> <div class="field"> <%= form.label :os %> <%= form.text_field :os, id: :targetserver_os %> </div> <div class="field"> <%= form.label :cpu %> <%= form.number_field :cpu, id: :targetserver_cpu %> </div> <%= form.fields(:disk, skip_id: true) do |disk| %> <%= hidden_field_tag :partitionname, id: :disk_partitionname, :value => "/" %> <%= disk.label :disk_size %> <%= disk.text_field :size, id: disk_size %> <% end %> <div class="actions"> <%= form.submit %> </div> <% end %>

#targetserverモデル

class Targetserver < ApplicationRecord has_many :disk accepts_nested_attributes_for :disk end

#diskモデル

class Disk < ApplicationRecord belongs_to :targetserver, optional: true end

#db/schema.rb

ActiveRecord::Schema.define(version: 20180105083156) do create_table "disks", force: :cascade, options: "ENGINE=InnoDB DEFAULT CHARSET=utf8" do |t| t.integer "serverid" t.string "partitionname" t.integer "size" t.datetime "created_at", null: false t.datetime "updated_at", null: false end create_table "targetservers", force: :cascade, options: "ENGINE=InnoDB DEFAULT CHARSET=utf8" do |t| t.string "hostname" t.string "os" t.integer "cpu" t.datetime "created_at", null: false t.datetime "updated_at", null: false end end

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

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

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

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

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

guest

回答2

0

自己解決

以下、継続の質問の中で解決できました。
https://teratail.com/questions/127205

投稿2018/07/19 10:06

07290729

総合スコア15

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

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

0

モデルの関連づけの誤りのみご指摘します。

まず,Targetserver モデルですが,has_many の引数は

rb

1has_many :disk

でなく

rb

1has_many :disks

のように複数形にしなければなりません。

また,Disk モデルのほうで,Targetserver を参照するカラムの名前が serverid となっていますが,命名規則に従って targetserver_id としなければなりません。

モデル(やマイグレーション)を作る時に references を使えばこんな間違いは防げます。

つまり,

rails generate model disk targetserver:references partitionname size:integer

という具合に,相手の名前+コロン+references とするのです。(相手の名前は snake_case で指定)

あとあとのことを考えてカラム名を変更することを強くお勧めしますが,どうしても現行のカラム名を使うなら,

rb

1belongs_to :targetserver, optional: true, foreign_key: 'serverid'

のように foreign_key(外部キー)オプションをあらわに指定する方法でいけると思います。

投稿2018/01/12 03:31

scivola

総合スコア2108

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

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

07290729

2018/01/12 08:53

scivolaさん 丁寧なご説明ありがとうございます。 モデル間の関連の設定方法が理解できました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問