首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Laravel/雄辩:反复阅读有经批准的评论文章的主题

Laravel/雄辩:反复阅读有经批准的评论文章的主题
EN

Stack Overflow用户
提问于 2018-04-20 06:52:56
回答 1查看 90关注 0票数 0

这是我的数据结构:

型号:

  • Topic hasMany Article
  • Article belongsTo TopichasMany Comment
  • Comment belongsTo Article
  • 此外,Topic hasManyThrough Comment (通过Article)

DB表:

  • topics:int id,string label
  • articles:int id,string content,int topic_id(外键)
  • comments:int id,string content,boolean approved,int article_id(外键)

现在,我想迭代所有有topicsapproved commentsarticles

代码语言:javascript
复制
@FOREACH ($topics->where(...) as $topic)
  <div> 
    {{ $topic->label }} has {{ $topic->articles->count() }} articles with approved comments.
  </div>
  ...
@ENDFOREACH

不幸的是,我不知道如何定义where-clause。或者应该是when-clause?这里是用于Laravel的方法列表。

任何帮助都是非常感谢的!

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-04-20 07:38:04

代码语言:javascript
复制
$topics = Topic::whereHas('articles', function ($query) {
    $query->whereHas('comments', function ($query) {
        $query->where('approved', true);
    });
})->get();

@foreach ($topics as $topic)
<div>
    {{ $topic->label }} has {{ $topic->articles->count() }} articles with approved comments.
</div>
@endforeach

或者,您也可以以类似的方式使用您的hasManyThrough关系,但是我没有一个示例来尝试它。

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

https://stackoverflow.com/questions/49935729

复制
相关文章

相似问题

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