【问题标题】:doctrine2 DQL subquery 1 row limit学说2 DQL子查询1行限制
【发布时间】:2013-02-13 17:50:57
【问题描述】:

我想做一个 DQL 查询,例如:

$dql = "select p
        from AcmeDemoBundle:UserTypeA p 
        where p.UserTypeB = :id
        and (
                 select top 1 r.boolean
                 from AcmeDemoBundle:Registry r
             ) 
        = true";

但似乎 TOP 1 它在学说 2 中不是有效功能。

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

【问题讨论】:

标签: doctrine-orm subquery limit dql


【解决方案1】:

DQL 不支持对子查询的限制,LIMITOFFSET 都不支持。

http://www.doctrine-project.org/jira/browse/DDC-885

【讨论】:

【解决方案2】:

虽然 Doctrine 本身并不支持这一点,但您可以实现一个名为 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)';
    }
}

(更多详情:https://www.colinodell.com/blog/201703/limiting-subqueries-doctrine-2-dql

你真的应该只将它用于只读目的,因为 Doctrine 不会在结果中包含其他相关实体(如果你保存它可能会变成孤立的或丢失)。

【讨论】:

    猜你喜欢
    • 2012-10-21
    • 2012-03-11
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2016-02-29
    • 1970-01-01
    相关资源
    最近更新 更多