Laravel을 사용하는 개발자라면 Eloquent Model의 강력함에 놀라실 수도 있지만, 강력한 표면 아래에는 아직 알려지지 않은 것들이 많이 있습니다. 이 글에서는 Laravel Eloquent의 10가지 강력한 기능을 공유할 것입니다.
1. 더욱 강력해진 find() 메소드
많은 개발자가 find()
메소드를 사용할 때 일반적으로 여기에 ID 매개변수만 전달합니다. 두 번째 매개변수: find()
方法的时候,通常就只是在这里传入一个 ID 的参数,其实我们也是可以传入第二个参数的:在 find()
方法中指定需要查找的字段
$user = App\User::find(1, ['name', 'age']); $user = App\User::findOrFail(1, ['name', 'age']); // 这里面的 name 和 age 字段就是制定只查找这两个字段
2.克隆 Model
直接使用 replicate()
方法即可,这样我们就很容易地创建一个 Model 的副本:
$user = App\User::find(1); $newUser = $user->replicate(); $newUser->save(); // 这样,$newUser 和 $user 的基本数据就是一样的
3.检查 Model 是否相同
使用 is()
方法检查两个 Model 的 ID 是否一致,是否在同一个表中:
$user = App\User::find(1); $sameUser = App\User::find(1); $diffUser = App\User::find(2); $user->is($sameUser); // true $user->is($diffUser); // false
4.在关联模型中同时保存数据
使用 push()
你可以在保存模型数据的同时,将所关联的数据也保存下来:
class User extends Model { public function phone() { return $this->hasOne('App\Phone'); } } $user = User::first(); $user->name = "GeiXue"; $user->phone->number = '1234567890'; $user->push(); // 最后这一行 push() 会将 user 的数据和 phone 的数据同时更新到数据库中
5.自定义 deleted_at 字段
如果你使用过 Laravel 的软删除 Soft Delete 的话,你应该就知道其实 Laravel 在标记一个记录为已删除的状态其实是用 deleted_at
这个字段来维护的,其实你是可以自定义这个字段的:
class User extends Model { use SoftDeletes; * The name of the "deleted at" column. * * @var string */ const DELETED_AT = 'deleted_date'; }
或者你这样自定义也可以:
class User extends Model { use SoftDeletes; public function getDeletedAtColumn() { return 'deleted_date'; } }
6.获取已修改的 Model 属性
使用 getChanges()
方法获取已被修改的属性:
$user->getChanges() //[ "name" => "GeiXue", ]
7.检查 Model 是否被修改
使用 isDirty()
方法就可以检测模型中的数据是否被修改:
$user = App\User::first(); $user->isDirty(); //false $user->name = "GeiXue"; $user->isDirty(); //true
在使用 isDirty()
的时候,你也可以直接检测某个属性是否被修改:
$user->isDirty('name'); //true $user->isDirty('age'); //false
8.获取 Model 的原始数据
在给 Model 的属性赋予新值的时候,你可以通过 getOriginal()
来获取原来的值:
$user = App\User::first(); $user->name; //JellyBool $user->name = "GeiXue"; //GeiXue $user->getOriginal('name'); //JellyBool $user->getOriginal(); //Original $user record
9.刷新 Model 的数据
使用 refresh()
刷新 Model 的数据,这在你使用 tinker
find()
메서드에서 찾을 필드를 지정하세요
$user = App\User::first(); $user->name; // JellyBool // 这个时候在其他地方,该用户的名字被更新为 GeiXue,你可以使用 refresh 来刷新,而不用退出 tinker $user->refresh(); $user->name; // GeiXue2. 모델을 복제하세요
replicate()
메서드를 직접 사용하세요. 모델의 복사본을 쉽게 만들 수 있습니다: