当前位置: 首页 > 知识库问答 >
问题:

具有多个关系的Laravel查询

楚俊迈
2023-03-14

我是新来laravel的,所以原谅我可能的愚蠢问题。此外,我确实研究了所有其他“类似”的问题,但要么它们没有重现正确的解决方案,要么我真的很难理解。

情景:

我有一个帖子模型和一个主题模型。这就是他们现在的样子。

在岗位上。php

public function subjects() {
    return $this->belongsToMany('Subject', 'posts_subjects');
}

在主题上。php

public function posts() {
    return $this->belongsToMany('Post', 'posts_subjects');
}

现在,我需要实现的是:

如果将查询参数传递给请求(即q=Food),我只想返回在主题关系中包含主题食物的帖子,而不返回其他帖子。如果什么都没有通过,那么我只是展示一切。。。

这就是我的PostsController的索引操作看起来像atm。

public function index() {

    $q = Input::get('q');

    $posts = Post::all();

    return View::make('posts.index', ['posts' => $posts]);
}

我该怎么做呢?非常感谢您的帮助。谢谢

PS.我可以用这个代码得到所有的帖子。

共有1个答案

钮轩昂
2023-03-14

这是未经测试的代码,但如果该查询只返回一个主题,则它可能适用于您:

public function index() 
{

    if($q = Input::get('q'))
    {
            if($subject = Subject::with('posts')->where('name', $q)->first())
            {
                $posts = $subject->posts;
            }
            else
            {
                $posts = array();
            }
    }
    else
    {
        $posts = Post::all();
    }


    return View::make('posts.index', ['posts' => $posts]);
}
 类似资料:
  • 我继承了一个项目,它有一些CRUD形式...在创建表单中,我们需要创建一个和关系的条目。所以基本上我得到的是以下这些 我不确定这是否是最好的方法,但似乎有效。 我遇到的问题是,在表单中,这些参与者/评论可以编辑、添加或删除,我不确定如何更新它们。是否可以更新它们,或者删除现有关系数据并重新添加它们是否更好? 我从来没有更新过关系,只是添加了它们,所以我不确定如何开始。 任何帮助都将不胜感激。

  • 问题内容: 有三个表:,并且,医院能提供的医疗服务和语言服务。因此,存在两个多对多关系。 简单ERD 现在,我想使用和搜索医院数据。 DaoImpl: 而且,如果我想从三个表中按邮政编码,医疗类型和语言进行搜索,那么如何编写一个jsql。 警告: 错误:org.hibernate.hql.internal.ast.ErrorCounter- 预期加入的路径!希望加入的路径!在org.hiberna

  • 我有一个桌子实验和一个桌子标签。一个实验可能有许多标签。架构: 是否可以使用返回实验和相应标签列表的jooq创建查询? 类似

  • 我需要支持一个涉及以下实体的场景(使用JPA): 用户 一个用户可以有多个帐户,一个帐户可以在多个用户之间共享,这是迄今为止的标准@ManyToMany关系。 一个用户可以为每个帐户拥有一组不同的角色,一个角色可以在多个用户之间共享。 我遵循了这个实践,它解释了一种用额外列映射多对多关联的方法,但我不确定我是否得到了它。 用户实体: 账户实体: 用户帐户实体: 用户帐号: 我正在创建一个新用户并尝

  • 我目前正在用Laravel构建我的第一个应用程序,我偶然发现了一个问题,即我不知道如何设置模型(用户和组)之间的多对多关系。 我已经创建了一个板,其中存储了所有用户和他们所在的组之间的关系。我的问题是,我不知道如何访问和设置这在Laravel。我不确定我是否必须用户has很多或属性。 我正试图找到一种方法,将用户添加到组中,以便在UserGroups表中创建一个新条目。 我的桌子: 用户 ID 集

  • 问题内容: Book,User和Review说,我正在构建具有复杂模型的应用程序。 评论包含书籍和用户ID。为了能够搜索至少包含一个评论的“图书”,我已将“图书”设置为“评论”的父级,并且具有这样的路由。但是,我还需要找到撰写包含某些短语的评论的用户。 是否可以同时将书和用户作为评论的父级?有没有更好的方法来处理这种情况? 请注意,我无法更改数据建模的方式/不愿意这样做,因为数据已从持久性数据库传