api-platform:嵌套对象集合过滤无效
创始人
2024-09-07 05:00:42
0

可以使用Doctrine的QueryBuilder,通过嵌套关联来解决这个问题。

下面是一个示例,假设有两个实体,Article和Comment,并且每个Article都有多个Comment嵌套在其中:

namespace App\Entity;

use Doctrine\Common\Collections\ArrayCollection;

class Article { private $id; private $title; private $comments;

public function __construct()
{
    $this->comments = new ArrayCollection();
}

// Getters and setters...

public function addComment(Comment $comment)
{
    $this->comments->add($comment);
    $comment->setArticle($this);
}

public function removeComment(Comment $comment)
{
    $this->comments->removeElement($comment);
    $comment->setArticle(null);
}

}

namespace App\Entity;

class Comment { private $id; private $content; private $article;

// Getters and setters...

public function setArticle(Article $article = null)
{
    $this->article = $article;
}

public function getArticle(): ?Article
{
    return $this->article;
}

}

现在,假设我们要获取所有标题中包含“api”的文章,这些文章中的评论必须包含内容“great”。我们可以使用以下代码:

namespace App\Repository;

use App\Entity\Article; use Doctrine\Bundle\DoctrineBundle\Repository\ServiceEntityRepository; use Doctrine\Common\Collections\Criteria; use Doctrine\ORM\Query\Expr; use Doctrine\Persistence\ManagerRegistry;

class ArticleRepository extends ServiceEntityRepository { public function __construct(ManagerRegistry $registry) { parent::__construct($registry, Article::class); }

public function findArticlesWithGreatComments(string $title)
{
    $qb = $this->createQueryBuilder('a');
    $qb
        ->join('a.comments', 'c')
        ->where(
            $qb->expr()->andX(
                $qb->expr()->like('a.title', ':title'),
                $qb->expr()->eq('c.content', ':content')
            )
        )
        ->setParameters

相关内容

热门资讯

存在八分钟!wpk微扑克辅助存... 存在八分钟!wpk微扑克辅助存在wpk ai机器人(的确是有挂的)-微博客户端;亲,关键说明,wpk...
ai辅助8分钟!WePoKe外... ai辅助8分钟!WePoKe外挂德州ai辅助神器(就是真的有挂)-知乎;1、德州ai辅助神器系统规律...
ai辅助五分钟!来玩德州有外挂... ai辅助五分钟!来玩德州有外挂aapoker线上规律(果真真的有挂)-小红书1、进入到来玩德州有外挂...
合作3分钟!微扑克有稳赢的打法... 合作3分钟!微扑克有稳赢的打法wpk德州辅助器是真的是假(就是真的有挂)-知乎1、wpk德州辅助器是...
ai代打2分钟!德扑之星创建房... ai代打2分钟!德扑之星创建房间设置aapoker软件有猫腻(果然真的有挂)-小红书1、点击下载安装...
输赢四分钟!云扑克德州有挂we... 输赢四分钟!云扑克德州有挂wepower辅助软件(其实真的有挂)-百度知乎1、下载好云扑克德州有挂辅...
透明挂一分钟!aapoker钻... 透明挂一分钟!aapoker钻石代理有挂的wpk俱乐部机器人(的确真的有挂)-今日头条;1、首先打开...
苹果版9分钟!微扑克辅助器是真... 苹果版9分钟!微扑克辅助器是真的德州aapoker俱乐部(果然真的有挂)-小红书;1、微扑克辅助器是...
私人局十分钟!德州ai辅助神器... 私人局十分钟!德州ai辅助神器软件wepoke辅助机器人(果真真的有挂)-微博客户端;1、下载好德州...
合作8分钟!德州之星辅助器可以... 合作8分钟!德州之星辅助器可以用pokernow可以加注(的确真的有挂)-今日头条1、玩家可以在德州...