在Laravel中wherehas用作于什么,基本用法是怎样
Admin 2022-06-14 群英技术资讯 1275 次浏览
这篇文章主要讲解了“在Laravel中wherehas用作于什么,基本用法是怎样”,文中的讲解内容简单、清晰、详细,对大家学习或是工作可能会有一定的帮助,希望大家阅读完这篇文章能有所收获。下面就请大家跟着小编的思路一起来学习一下吧。在laravel中,wherehas基于关联关系去过滤模型的查询结果,并且允许添加对这个模型的过滤条件,常用于过滤主表中有关从表的数据,语法为“User::whereHas('从表', function($...){$...->where(过滤条件);})->get()”。

本文操作环境:Windows10系统、Laravel6版、Dell G3电脑。
with()
with()方法是用作“渴求式加载”的,那主要意味着,laravel将会伴随着主要模型预加载出确切的的关联关系。这就对那些如果你想加在一个模型的所有关联关系非常有帮助。因为“渴求式加载”缓解了1+N的查询问题,仅需1+1次查询就能解决问题,对查询速度有了质的提升。
例如:
user > hasMany > post
$users = User::with('posts')->get();
foreach($users as $user){
$users->posts; // posts已经被加载了,没有增加DB查询
}has()
has()方法是基于关联关系去过滤模型的查询结果,所以它的作用和where条件非常相似。如果你只使用has(‘post’),这表示你只想得到这个模型,这个模型的至少存在一个post的关联关系。
例如:
user > hasMany > post
//User至少有一条post的关联关系
$users = User::has('post')->get();你还可以使用”.“来构造嵌套has语句。
例如:
user > hasMany > post
$user = User::has('post.votes', ‘>’, '3')->get();whereHas()
whereHas()方法的原理基本和has()方法相同,但是他允许你自己添加对这个模型的过滤条件。
例如:
user > hasMany > post
$users = User::whereHas('posts', function($q){
$q->where('created_at', '>=', '2017-11-29');
})->get();
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要为大家详细介绍了PHP实现文字写入图片功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
我们在做项目的时候,有些需求,特别是数据的响应处理需要花费大量的时间,由于php是一个短生命周期的脚本语言,到了默认的30秒,php的数据处理还没完成,php的生命周期就结束了。这时需要使用异步并发处理策略,也就是说,一次php调用可以发出的多个请求,这些请求不是按照顺序执行,而是可以异步并发执行的,一些请求用于在后台处理数据,一些请求用于接受后台响应状态,根据状态,与用户做一些简单的交互。但是问题来了,我们都知道php本身是不支持多线程的,那么应该怎么实现php的多线程呢?
在说明名称解析规则之前,我们先看一些重要的定义:命名空间名称定义非限定名称名称中不包含命名空间分隔符的标识符,例如 Foo限定名称名称中含有命名空间分隔符的...
thinkphp中i方法的代码是“I(‘变量类型.变量名’,[‘默认值’],[‘过滤方法’],[‘额外数据源’])”;i方法命名来自“input”,是输入的意思,用于更加方便和安全的获取系统输入变量,必要时还可以对变量值进行过滤及强制转换。
在php中有两个函数,能够实现数字补零,str_pad()sprintf() 函数1: str_pad顾名思义这个函数是针对字符串来说的这个可以对指定的字符串填补任何其它的字符串例如:str_pad(带填补的字符串,填补后的长度,填补字符串,填补位置)其中填补后的长度必须是个正整数,填补位置有三个选项,左边:STR_PAD_LEFT,右边:STR_PAD_RIGHT,两
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
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