Laravel ORM 中你不知道的骚操作
append
class User extends Model
{
protected $appends = ['is_adult'];
public function getIsAdultAttribute()
{
return $this->attribute['age'] > 18;
}
}
这个操作大家是不是都用过,在模型里新增一个数据库不存在的字段,非常方便。但是 $appends 是全局的,所有的查询中都会添加 is_adult 这个字段。
User::select('id', 'name')->first();
像这样查询的时候甚至还会报错提示 age 字段不存在。
我们可以像这样,在查询的时候再将 is_adult 添加进查询结果集中。
$user = User::first();
$user->append('is_adult');
你以为这就完了么?不仅仅如此,如果我们查询的是多个用户怎么办,难道自己 for 循环 append 一遍么?不不不,我们优雅的 Laravel 已经为我们考虑过了。
$user = User::paginate(10);
$user->each->append('is_adult');
query
User::where('sex', 'girl')->where('age', '<=', 20)->where('money', '>', 1000000000000)->get();
这种查询语句大家是不是经常写啊?有没有发现一个问题?本来找个富萝莉就挺难得,还没有提示。

这怎么能忍,稍稍改写一下,在最前面加个 query ,轻轻松松娶富萝莉走上人生巅峰。

where
富萝莉没找到的话,降低点要求正儿八经找个女朋友吧。虽然有点难,但是如果你知道她的 ID,就可以直接使用
User::query()->find(2);
找到她,简单快捷。那要是不知道 ID 只知道名字的情况下咋整呢?写where条件?告诉你个更快捷的方法,毕竟找女朋友不能等。
User::query()->firstWhere(['name' => '乔碧萝']);
先写这么多,发现其他骚操作再更
。
本作品采用《CC 协议》,转载必须注明作者和本文链接
更多文章去我的博客 看看
本帖由系统于 5年前 自动加精
关于 LearnKu
User::whereName('wang')->get()where+字段名的操作也比较骚常规操作,常规操作😂
appends 这个确实不错
append很实用,以前都是老实循环append
基操,坐下,勿6
不够骚,希望整点更骚的来 :grin:
M.
细看 6.* 文档, 或者直接搜索 append ,没有什么是文档没有的;如果有那是你找的不对;或则直接 去看 英文的API 文档
奇巧淫技 :sweat_smile:
的确有些
骚这…难道不是常规操作?
laravel5.7 不用调用
append和each,自动为每个模型追加了。laravel这些搞太多了 感觉一直用它的奇巧淫技会被行为绑架 :joy: data_get()这玩意儿可以调用方法 :confused:
对于append这个问题,我是做了一个package来解决的 github.com/terranc/laravel-eloquen...
不错,appends 确实还没注意到。
$user = User::paginate(10); $user->each->append('is_adult'); 我这样写 会报未定义属性:Illuminate\Pagination\LengthAwarePaginator::$each
append和query都很实用,大神啊