在Laravel中scope作用是什么,如何使用
Admin 2022-06-14 群英技术资讯 1057 次浏览
这篇文章主要介绍“在Laravel中scope作用是什么,如何使用”,有一些人在在Laravel中scope作用是什么,如何使用的问题上存在疑惑,接下来小编就给大家来介绍一下相关的内容,希望对大家解答有帮助,有这个方面学习需要的朋友就继续往下看吧。在laravel中,scope用于处理模型中的数据,在模型中可以定义scope开头方法,这类方法可以通过模型直接调用,被称为查询作用域,语法为“public function scope首字母大写单词($query){...}”。

本文操作环境:Windows10系统、Laravel8版、Dell G3电脑。
laravel中的scope作用域
laravel中在模板中处理(属于不属于)的数据(增删改查),引入了scope来处理
也就是在模板定义方法中,加上前缀scope。
简言之,Laravel中模型中可以定义scope开头方法,这类方法可以通过模型直接调用。这类方法也称作查询作用域。
在数据查询中经常会使用条件查询,这些查询条件有些是相同的,scope可以实现这些相同条件查询的复用。
普通 scope
定义
方法名为 scope + 首字母大写单词 (这个可以随便定义)
public function scopeStatus($query)
{
return $query->where('status',1);
}使用
其中调用去掉 scope 后,首字母小写的那个函数。
scopeStatus () 调用 status ()。
User::status()->get();
全局 scope
我们需要重新定义 boot 方法,集成父类 boot 以后,添加全局 scope,这样默认就已经全局使用了。
protected static function boot()
{
parent::boot(); // TODO: Change the autogenerated stub
static::addGlobalScope('avaiable',function (Builder $builder){
$builder->whereIn('status', [0, 1]);
});
}我们有的时候有的查询是不需要这个全局 scope 的时候,我们只需要去掉就可以。
使用 withOutGlobalScope()方法
Post::withOutGlobalScope('avaiable')->get();
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
两种方法:第一种不在介绍 太麻烦第二种方法:php ext目录:举个栗子:Mysql_PDOcd pdo_mysql //里面没有configure 的文件,用phpize来扩展模块/usr/local/php/bin/phpize yum install autoconf -y //autoconf是一个用于生成可以自动的配置软件源代码包以适应多种UNIX系统的s...
我们知道PHP是属于弱类型语言,与Java和C++这些强类型语言不同,弱类型语言是自动转换数据类型的,强类型语言必须手动什么类型。那么PHP数据类型如何转换呢?有几种转换方法?下面我们一起来来了解一下。
在PHP编程中,想要提高在编写程序过程中的性能技术,一些小技巧绝对不能放过。想要了解有哪些内容的小伙伴们,可以跟随小编来了解了解。
php怎样实现格式化时间?我们有时候会遇到需要格式化时间的需求,那么要怎么操作呢?下面就给大家分享关于php实现格式化时间操作的实例,感兴趣的朋友可以了解看看。
许多人都说算法是程序的核心,算法的好坏决定了程序的质量。作为一个初学者,虽然很少接触到算法方面的东西。但是对于基本的排序算法还是应该掌握的,它是程序开发的必备...
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008