doujiena0025 2017-06-02 09:19
浏览 77
已采纳

在symfony / doctrine中查询not null OneToMany关系

I am using Symfony 3.2. I have an entity called Site which contains a OneToMany relationship to another entity called Indication.

class Site
{
    /**
     * @ORM\OneToMany(targetEntity="IhkBundle\Entity\Indication", mappedBy="site")
     */
    private $indications;
}

class Indication
{
    /**
     * @ORM\ManyToOne(targetEntity="IhkBundle\Entity\Site", inversedBy="indications")
     * @ORM\JoinColumn(name="site_id", referencedColumnName="id")
     */
    private $site;
}

I want to query for all sites where Indications are available. I only get an ArrayCollection which I don't know what to do with.

$sites = $repository->findAll();
foreach ($sites as $site) {
   $site->getIndications();
}

I also tried to use the queryBuilder like in this answer.

$query = $repository->createQueryBuilder('s');
$result = $query->where('s.indications IS NOT NULL')
    ->getQuery()
    ->getResult();

which throws the following error:

[Semantical Error] line 0, col 46 near 'indications IS': Error: Invalid PathExpression. StateFieldPathExpression or SingleValuedAssociationField expected.
  • 写回答

1条回答 默认 最新

  • dongqiongjiong4740 2017-06-02 09:28
    关注

    Seems like this can be solved by SQL by doing a simple join, something like this should work:

    $query = $repository->createQueryBuilder('s');
    $result = $query->select('p')
        ->join('p.indications', 'i')
        ->getQuery()
        ->getResult();
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 Attention is all you need 的代码运行
  • ¥15 一个服务器已经有一个系统了如果用usb再装一个系统,原来的系统会被覆盖掉吗
  • ¥15 使用esm_msa1_t12_100M_UR50S蛋白质语言模型进行零样本预测时,终端显示出了sequence handled的进度条,但是并不出结果就自动终止回到命令提示行了是怎么回事:
  • ¥15 前置放大电路与功率放大电路相连放大倍数出现问题
  • ¥30 关于<main>标签页面跳转的问题
  • ¥80 部署运行web自动化项目
  • ¥15 腾讯云如何建立同一个项目中物模型之间的联系
  • ¥30 VMware 云桌面水印如何添加
  • ¥15 用ns3仿真出5G核心网网元
  • ¥15 matlab答疑 关于海上风电的爬坡事件检测