Laravel Eloquent 小技巧

1. 获取原始属性

当修改一条Eloquent 模型记录的时候你可以通过调用getOriginal()方法获取记录的原始属性

$user = App\User::first();
$user->name;   // John
$user->name="Peter";   //Peter
$user->getOriginal('name');   //John
$user->getOriginal();   // 原始$user记录

2. 检查模型是否被修改

使用isDirty()方法确定模型或给定属性是否已被修改

$user = App\User::first();
$user->isDirty();   //false

$user->name="Peter";
$user->isDirty();  //true

也可以检查指定属性是否被修改。

$user->isDirty("name"); //true
$user->isDirty("age");  //false

3.获取更改的属性

使用 getChanges()获取更改的属性

$user->getChanges();    // [ "name" =>"Peter",]

注:仅当您使用 syncChanges()保存模型或同步更新时,才生效

4. 定义deleted_at字段

默认情况下,laravel使用deleted_at字段处理软删除。你可以通过定义DELETED_AT属性来更改它

class user extends Model{
	use SoftDeletes;
	* The name of the "deleted at" column.
     *
     * @var string
     */
    const DELETED_AT = 'is_deleted';
}

或者定义访问

class User extends model{
	use SoftDeletes;
	public function getDeletedAtColumn(){
		return 'is_deleted';
	}
}

5. 保存模型和关系

你可以使用push()方法保存模型及其联系。

class user extends Model{
	public function phone(){
		return $this->hasOne('App\phone');
	}
}
 $user = User::first();
 $user->name = "Peter";
 
 $user->phone->number = "1234567890";
 $user->push();   // 这将更新数据库中的用户和电话

6. 重新加载模型

使用 fresh()重新从数据库加载一个数据模型

$user->App\User::first();
$user->name;   //John

// user 表被其他进程修改。例:数据库又插入一条"name""Peter" 的数据。

$updatedUser = $user->fresh();
$updatedUser ->name;    //Peter

$user->name;   //John

7. 重新加载现有模型

你可以使用refresh()方法从数据库重新加载具有新值的现有模型。

$user = App\User::first();
$user->name;               // John

// user 表被其他进程修改。例: “name” 被修改为 “Peter” 。

$user->refresh();
$user->name;              // Peter

注:refresh()也会更新模型的关联模型数据

8. 检查模型是否为同一个

使用```is()``方法确定两个模型是否拥有形同主键并且属于同一张表

$user = App\User::find(1);
$sameUser = App\User::find(1);
$diffUser  = App\User::find(2);

$user->is($sameUser);     //true
$user->is($diffUser);     //false

9. 克隆一个模型

你可以使用replicate()方法来复制一个模型到一个新的对象中。

$user = App\User::find(1);
$newUser = $user->repliccate();

$newUser->save();

10. 在find()方法中指定查找的属性

当使用find()或者findOrFail()方法时,传入第二个参数可以指定需要查找的属性。

$user = App\User::find(1,['name','age']);
$user = App\User::findOrFail(1,['name','age']);






转自 PHP/Laravel 开发者社区  https://laravel-china.org/top
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值