我想做一个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它不是doctrine2中的有效函数。
我无法弄清楚如何将子查询的结果限制为一行。
答案 0 :(得分:2)
DQL不支持对子查询的限制,也不支持LIMIT
和OFFSET
。
答案 1 :(得分:1)
虽然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不会在结果中包含其他相关实体(如果保存它可能会变成孤立或丢失)。