Doctrine orm doctrine2 DQL子查询1行限制

Doctrine orm doctrine2 DQL子查询1行限制,doctrine-orm,subquery,limit,dql,Doctrine Orm,Subquery,Limit,Dql,我想执行DQL查询,如: $dql = "select p from AcmeDemoBundle:UserTypeA p where p.UserTypeB = :id and ( select top 1 r.boolean from AcmeDemoBundle:Registry r ) = true"; 但它似乎不是doctr

我想执行DQL查询,如:

$dql = "select p
        from AcmeDemoBundle:UserTypeA p 
        where p.UserTypeB = :id
        and (
                 select top 1 r.boolean
                 from AcmeDemoBundle:Registry r
             ) 
        = true";
但它似乎不是doctrine2中的有效函数


我不知道如何将子查询的结果限制为一行。

DQL不支持对子查询的限制,也不支持
limit
OFFSET


请参见

尽管条令本机不支持此功能,但您可以实现名为
FIRST()
的自定义函数来实现此功能:

<?php

use Doctrine\ORM\Query\AST\Functions\FunctionNode;
use Doctrine\ORM\Query\AST\Subselect;
use Doctrine\ORM\Query\Lexer;
use Doctrine\ORM\Query\Parser;
use Doctrine\ORM\Query\SqlWalker;

/**
 * FirstFunction ::=
 *     "FIRST" "(" Subselect ")"
 */
class FirstFunction extends FunctionNode
{
    /**
     * @var Subselect
     */
    private $subselect;

    /**
     * {@inheritdoc}
     */
    public function parse(Parser $parser)
    {
        $parser->match(Lexer::T_IDENTIFIER);
        $parser->match(Lexer::T_OPEN_PARENTHESIS);
        $this->subselect = $parser->Subselect();
        $parser->match(Lexer::T_CLOSE_PARENTHESIS);
    }

    /**
     * {@inheritdoc}
     */
    public function getSql(SqlWalker $sqlWalker)
    {
        return '(' . $this->subselect->dispatch($sqlWalker) . ' LIMIT 1)';
    }
}

类似的问题,但也没有答案:(这里可能有一个解决方案我知道,我知道,我正在寻找任何替代代码。不知道是否可以使用createQuery。通过NativeSQL()执行)