9
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

LaravelのfirstOrNewメソッドでMassAssignmentExceptionエラーが発生した時の対応

Last updated at Posted at 2016-06-27

概要

Laravelで、モデルから新しいレコードを生成し保存するメソッドとして、firstOrNewメソッドを使用しているのですが、MassAssignmentExceptionエラーが発生して使用できないという問題があったので、その時の対応を備忘録として記します。

firstOrNewメソッドとは

Laravelの公式ドキュメントには以下のように書かれています。

http://readouble.com/laravel/5/1/ja/eloquent.html#inserting-and-updating-models
firstOrNewメソッドもfirstOrCreateのように指定された属性にマッチするデータベースのレコードを見つけようとします。しかしモデルが見つからない場合、新しいモデルインスタンスが返されます。firstOrNewが返すモデルはデータベースに保存されていないことに注目です。保存するにはsaveメソッドを呼び出す必要があります。

以下のように指定することで、条件に合うレコードが存在すればfirst()メソッドで最初の1件を取得し、存在しなければ新しいインスタンスを取得する、というメソッドです。

// 属性のフライトか、存在しなければ新しいインスタンスを取得する…
$flight = App\Flight::firstOrNew(['name' => 'Flight 10']);

MassAssignmentExceptionエラーの発生

このfirstOrNew()メソッドを利用している箇所が動作せず、MassAssignmentExceptionエラーが発生していました。
ずっと原因がわからなかったのですが、調べてみると、save()create()メソッドを使用するときは、モデルに$fillable$guarded属性のどちらかを設定しなければいけないようでした。

公式ドキュメントをよく見ると以下のように書いてあります。

http://readouble.com/laravel/5/1/ja/eloquent.html#inserting-and-updating-models
一行だけで新しいモデルを保存するにはcreateメソッドが利用できます。挿入されたモデルインスタンスがメソッドから返されます。しかしこれを利用する前にEloquentモデルを複数代入から保護するために、モデルへfillableかguarded属性のどちらかを設定する必要があります。

$guardedには絶対に変更しないカラムを、$fillableには変更するかもしれないカラムを設定する必要があります。
以下の記述を対象のモデルに追加することで、firstOrNew()を実行することができました :relaxed:

// 絶対に変更しないカラム
protected $guarded = ['id'];
9
4
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
9
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?