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

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

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

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

Q&A

1回答

1358閲覧

Rails で1対多で関連付けした新規レコードの作り方を教えていただけないでしょうか?

koume

総合スコア458

Ruby on Rails 5

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

0グッド

0クリップ

投稿2018/09/27 07:30

Rails5.1.3でWebアプリケーション制作の勉強をしています。
customersテーブルと1体多で関連付けたhistoriesテーブルに新規にcustomersテーブルにレコードを保存すると同時にhistoriesテーブルにレコードを作りたいのですが上手く作れないので教えていただけないでしょうか?
$ rails c で試していますが上手くいかないので教えていただけないでしょうか?

customer.rb class Customer < ActiveRecord::Base has_many :histories, dependent: :destroy, autosave: true end
history.rb class History < ActiveRecord::Base belongs_to :customer end
customer_form.rb class Visitor::CustomerForm include ActiveModel::Model attr_accessor :customer, :inputs_home_address delegate :persisted?, :save, to: :customer def initialize(customer = nil) @customer = customer @customer ||= Customer.new (2 - @customer.personal_phones.size).times do @customer.personal_phones.build end self.inputs_home_address = @customer.home_address.present? @customer.build_home_address unless @customer.home_address @customer.build_histories unless @customer.histories ------ここが上手くいきません end

$ rails cで試した内容

irb(main):001:0> @customer = Customer.find(103) ---idが103のレコードを取得 irb(main):002:0> @customer.build_home_address unless @customer.home_address   HomeAddress Load (0.4ms) SELECT `addresses`.* FROM `addresses` WHERE `addresses`.`type` IN ('HomeAddress') AND `addresses`.`customer_id` = 103 LIMIT 1 => #<HomeAddress id: nil, customer_id: 103, type: "HomeAddress", postal_code: nil, prefecture: nil, city: nil, address1: nil, address2: nil, created_at: nil, updated_at: nil>---home_addressのレコードは出来ているようです。 irb(main):003:0> @customer.build_histories unless @customer.histories => nil------nilとなり新規にレコードができていません。 試しにやってみたこと irb(main):017:0> @customer.histories History Load (0.4ms) SELECT `histories`.* FROM `histories` WHERE `histories`.`customer_id` = 103 LIMIT 11 => #<ActiveRecord::Associations::CollectionProxy []>

どなたか教えていただけないでしょうか?宜しくお願いします。

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

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

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

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

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

guest

回答1

0

#<ActiveRecord::Associations::CollectionProxy []>は真と評価されます。
ゆえに、「空のときに作る」ことを実現できていません。

if @customer.histories.empty?を評価するのが正しいと思います。

投稿2018/09/28 10:21

takumiabe

総合スコア661

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問