首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >拉拉维尔雄辩的关系:->user()、->favorites()、->get()和auth()->user()->favorites之间的差异

拉拉维尔雄辩的关系:->user()、->favorites()、->get()和auth()->user()->favorites之间的差异
EN

Stack Overflow用户
提问于 2022-09-05 10:52:01
回答 1查看 38关注 0票数 0

用户模型:

代码语言:javascript
复制
    public function favorites()
    {
        return $this->hasMany(Favorite::class);
    }

主计长:

代码语言:javascript
复制
 //return auth()->user()->favorites()->get();
 //return auth()->user()->favorites;

有人能解释一下这两种代码之间的差异吗?我什么时候该用每一个?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-09-05 13:36:21

让我实际解释一下:

如果上面的查询如下所示

代码语言:javascript
复制
// return auth()->user()->favorites()->where('active', true)->get();
// return auth()->user()->favorites->where('active', true);

然后它的SQL查询如下

代码语言:javascript
复制
// SQL of first query
select * from `favorites` where `favorites`.`user_id` = 1 and `favorites`.`user_id` is not null and `active` = 1

// SQL of second query    
select * from `favorites` where `favorites`.`user_id` = 1 and `favorites`.`user_id` is not null

您看到了两种SQL?的不同之处吗?

现在,让我用文字解释一下:

如果您在上面的favorites()之后添加了一些条件,它将从数据库中获取所有过滤的结果。但是,如果在favorites之后添加一些条件,它将过滤已经从数据库中获取的结果。

虽然我不擅长解释,但我希望您能清楚地理解这两种代码之间的关系。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/73608220

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档