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
宜しくお願いします。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。