Laravel ORM 中你不知道的骚操作

2020-05-1905:30:37后端程序开发Comments1,837 views字数 852阅读模式

Laravel ORM 中你不知道的骚操作文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/19115.html

append文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/19115.html

    class User extends Model
    {
        protected $appends = ['is_adult'];
        public function getIsAdultAttribute()
        {
            return $this->attribute['age'] > 18;
        }
    }

这个操作大家是不是都用过,在模型里新增一个数据库不存在的字段,非常方便。但是 $appends 是全局的,所有的查询中都会添加 is_adult 这个字段。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/19115.html

User::select('id', 'name')->first();

像这样查询的时候甚至还会报错提示 age 字段不存在。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/19115.html

我们可以像这样,在查询的时候再将 is_adult 添加进查询结果集中。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/19115.html

    $user = User::first();
    $user->append('is_adult');

你以为这就完了么?不仅仅如此,如果我们查询的是多个用户怎么办,难道自己 for 循环 append 一遍么?不不不,我们优雅的 Laravel 已经为我们考虑过了。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/19115.html

    $user = User::paginate(10);
    $user->each->append('is_adult');

query文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/19115.html

     User::where('sex', 'girl')->where('age', '<=', 20)->where('money', '>', 1000000000000)->get();

这种查询语句大家是不是经常写啊?有没有发现一个问题?本来找个富萝莉就挺难得,还没有提示。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/19115.html

Laravel ORM 中你不知道的骚操作文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/19115.html

这怎么能忍,稍稍改写一下,在最前面加个 query ,轻轻松松娶富萝莉走上人生巅峰。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/19115.html

Laravel ORM 中你不知道的骚操作文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/19115.html

where文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/19115.html

富萝莉没找到的话,降低点要求正儿八经找个女朋友吧。虽然有点难,但是如果你知道她的 ID,就可以直接使用文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/19115.html

User::query()->find(2);

找到她,简单快捷。那要是不知道 ID 只知道名字的情况下咋整呢?写 where 条件?告诉你个更快捷的方法,毕竟找女朋友不能等。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/19115.html

User::query()->firstWhere(['name' => '乔碧萝']);

先写这么多,发现其他骚操作再更。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/19115.html

  • 本站内容整理自互联网,仅提供信息存储空间服务,以方便学习之用。如对文章、图片、字体等版权有疑问,请在下方留言,管理员看到后,将第一时间进行处理。
  • 转载请务必保留本文链接:https://www.cainiaoxueyuan.com/bc/19115.html

Comment

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定