php教程laravel中wherehas是干什么用的

 所属分类:php教程

 浏览:158次-  评论: 0次-  更新时间:2022-12-12
描述:更多教程资料进入php教程获得。 在laravel中,wherehas基于关联关系去过滤模型的查询结果,并且允许添加对这个模型的过滤条件,常用于过滤...
更多教程资料进入php教程获得。

在laravel中,wherehas基于关联关系去过滤模型的查询结果,并且允许添加对这个模型的过滤条件,常用于过滤主表中有关从表的数据,语法为“User::whereHas('从表', function($...){$...->where(过滤条件);})->get()”。

Laravel 9 保姆级视频教程,想学不会都难!进入学习

本文操作环境:Windows10系统、Laravel6版、Dell G3电脑。

laravel中wherehas

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();
登录后复制

【相关推荐:laravel视频教程】

以上就是laravel中wherehas是干什么用的的详细内容,更多请关注zzsucai.com其它相关文章!

 标签: Laravel,
积分说明:注册即送10金币,每日签到可获得更多金币,成为VIP会员可免金币下载! 充值积分充值会员更多说明»

讨论这个素材(0)回答他人问题或分享使用心得奖励金币

〒_〒 居然一个评论都没有……

表情  文明上网,理性发言!