前提・実現したいこと
商品検索システムのようなものを作っており,
- 店名(shops)
- 支店名(branchs)
発生している問題・エラーメッセージ
View→コントローラー→テーブルと入力値(店名と支店名)を移していくプログラムを作ったのですが,以下のように支店名が送れないエラーが出てしまいました。
私個人では解決ができなかっため,思い当たる原因などあればご教示頂きたいです。
SQLSTATE[HY000]: General error: 1364 Field 'branch_id' doesn't have a default value (SQL: insert into `shops` (`name`, `updated_at`, `created_at`) values (店名, 2019-03-15 02:04:15, 2019-03-15 02:04:15))
該当のソースコード
【index.blade.php】(View)
php
1<form action="/" method="POST" class="form-horizontal"> 2 <input type="text" name="shop" class="form-control" placeholder="店名" autocomplete="off"> 3 <input type="text" name="branch" class="form-control" placeholder="支店" autocomplete="off"> 4</form>
【web.php】(Routes)
php
1Route::post('/', 'MyController@store');
【MyController.php】(Controller)
php
1public function store(Request $request) 2 { 3 // branchsテーブルへの書き込み 4 $branch = new branch; 5 $branch_posted = $request->input('branch'); 6 branch::updateOrCreate(['name'=> $branch_posted], ['name'=> $branch_posted]); 7 8 // shopsテーブルへの書き込み 9 $branch_id_added = branch::where('name', $branch_posted)->get(); // branchsに追加したid 10 shop::updateOrCreate(['branch_id' => $branch_id_added, 'name' => $request->input('shop')]); 11 return redirect('/'); 12 }
【shop.php】(Model)
php
1class shop extends Model 2{ 3 protected $fillable = ['name']; 4 5 public function items() 6 { 7 return $this->hasMany('App\branch'); 8 } 9}
【branch.php】(Model)
php
1class branch extends Model 2{ 3 public function shops() 4 { 5 return $this->belongsTo('App\shop'); 6 } 7}
試したこと
- shopsテーブルやshopモデルの削除→再作成を行ってみましたが,同じ結果でした。
- StrictModeに関する情報を参考に,database.phpにて 'mysql' => ['prefix_indexes' => false] としてみましたが,
"SQLSTATE[23000]: Integrity constraint violation: 1452 Cannot add or update a child row: a foreign key constraint fails (`my_db`.`shops`, CONSTRAINT `shops_branch_id_foreign` FOREIGN KEY (`branch_id`) REFERENCES `branchs` (`id`) ON DELETE CASCADE ON UPDATE CASCADE) (SQL: insert into `shops` (`name`, `updated_at`, `created_at`) values (店名, 2019-03-15 02:22:53, 2019-03-15 02:22:53)) ◀"
というようなエラーが出てしまいました。
補足情報(FW/ツールのバージョンなど)
OS:Windows10
Apache 2.4.38
PHP Version 7.1.26
Laravel Framework 5.8.4
かなりとんちんかんなことをしていましたが,回答頂いた情報+コントローラの下記の書き換えで動かすことができました。
後学のために。
php
1$shop_posted = $request->input('shop'); 2$branch_posted = $request->input('branch'); 3 4$shop = new shop; 5shop::updateOrCreate(['name'=> $shop_posted], ['name'=> $shop_posted]); 6 7// branch_shop 8$shop_added = shop::where('name', $shop_posted)->first(); // branchesに追加したオブジェクト 9$shop_added->branches()->updateOrcreate(['name' => $branch_posted]);
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2019/03/15 13:35