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

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

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

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

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

Q&A

解決済

1回答

1708閲覧

Railsで新規登録時に関連テーブルを作成するときのエラー解消方法を教えてください。

koume

総合スコア458

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

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

0グッド

0クリップ

投稿2018/01/10 07:16

rails5.1.3でWebアプリケーションを作成しております。
Customerテーブルに新規に登録する際に、関連付けられたテーブルも新規に作成するように記述していましたが、
bankテーブルを作成するときに下記のエラーが発生しています。
調べてみると、accountカラムにデフォルト値がありませんというエラーのようですが、マイグレーションの記述に
デフォルト値が入るようにしてもエラーが解消されません。
何が原因かわからずに困っているので教えていただけないでしょうか?
エラーの内容は以下になります。

ActiveRecord::NotNullViolation in Visitor::CustomersController#create Mysql2::Error: Field 'account' doesn't have a default value: INSERT INTO `banks` (`customer_id`, `created_at`, `updated_at`) VALUES (116, '2018-01-10 06:49:12', '2018-01-10 06:49:12') Extracted source (around line #5): 4 attr_accessor :customer, :inputs_home_address 5  delegate :persisted?, :save, to: :customer 6 7 def initialize(customer = nil) 8 @customer = customer

マイグレーションは以下になっています。

class CreateBanks < ActiveRecord::Migration[5.1] def change create_table :banks do |t| t.references :customer, null: false # 顧客への外部キー t.string :bk_name, null: false, default: '' # 銀行名 t.string :office, null: false, default: '' # 支店 t.integer :account, null: false, default: 128 # 口座番号--------デフォルト値を 128 にする。 t.timestamps end add_foreign_key :banks, :customers add_index :banks, :bk_name add_index :banks, :office add_index :banks, :account end end

関連付けられたテーブルを作成するコードは以下になります。

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(gender: 'male') (2 - @customer.personal_phones.size).times do @customer.personal_phones.build end self.inputs_home_address = @customer.home_address.blank? @customer.build_home_address unless @customer.home_address (2 - @customer.home_address.phones.size).times do @customer.home_address.phones.build end @customer.build_register unless @customer.register @customer.build_sponsor unless @customer.sponsor @customer.build_score unless @customer.score @customer.build_eighteen unless @customer.eighteen @customer.build_nineteen unless @customer.nineteen @customer.build_twentie unless @customer.twentie @customer.build_one unless @customer.one @customer.build_member unless @customer.member @customer.build_point unless @customer.point @customer.build_special unless @customer.special @customer.build_bank unless @customer.bank------------------------bankテーブル作成時にエラー発生。 end

宜しくお願いします。

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

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

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

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

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

guest

回答1

0

自己解決

マイグレーションを書き換えていたのに bin/rails db:migrate:resetを
実行していませんでした。
実行し解決しました。

投稿2018/01/10 07:51

koume

総合スコア458

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問