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();