laravel 查询作用域

laravel 查询作用域

简介

这里介绍的是局部查询作用域,

局部查询作用域

就是将该模型常用的where条件进行封装,
每次where时调个方法即可。

全局查询作用域

就是每次调用模型查询都会进行条件过滤,
感觉应用场景不多,也没看,就不介绍了。

使用

  • 在model中,创建加上一个 scope 前缀的方法即可
class News extends Model
{
    const TABLE = 'news';

	//只包含展示的新闻的查询作用域
    public function scopeScoShow($query)
    {
        return $query->where('is_show', 1);
    }

	//只包含某个类型的查询作用域,带参数
    public function scopeScoType($query, $type)
    {
        return $query->where('type', $type);
    }

}

调用

//使用时调用,首字母小写
News::scoShow()->get();

//带参数
News::scoShow()->scoType(2)->get();
posted @ 2019-12-07 17:08  pine007  阅读(307)  评论(0编辑  收藏  举报