Symfony Doctrine,通过连接从子查询中选择

Sam*_*ung 5 php sql symfony doctrine-orm

还没有找到一个可靠的解决方案,但我有一个 mySQL 查询,我想将其转换为 Doctrine。它是从带有连接的子查询中进行选择,我可能在某处读到 Doctrine 的子查询中不允许连接。

这是 SQL:

SELECT part, SUM(qty) as qty FROM (SELECT part, SUM(qty) as qty FROM sub LEFT JOIN main ON main.id = main_id WHERE hold != 1 GROUP BY name, part) AS tbl GROUP BY part

这就是我尝试过的,但都是错误的。

 $em = $this->getDoctrine()->getManager();

    $q = $em->createQuery('v');
    $q2 = $em->createSubQuery()
        ->select('m.part, sum(s.qty) qty')
        ->from('Sub s')
        ->leftJoin('s.main m')
        ->where('s.hold != 1')
        ->groupBy('m.part');

    $q->select('m.part, sum(qty)', $q2->getDQL());
Run Code Online (Sandbox Code Playgroud)

我遇到的第一个错误是:

FatalErrorException: Error: Call to undefined method Doctrine\ORM\EntityManager::createSubQuery() in ....Controller.php line 238

我很确定我做错的不仅仅是这一点,而且这是即将发生的第一件事。那么getManager()显然没有createSubQuery()功能?这样做的正确方法是什么?

Bar*_*tek 4

没有类似的方法createSubQuery()。看看这个答案:/sf/answers/753435091/