我正在尝试使用querybuilder()
在教义中使用GROUP_CONCAT()我试过这个
$qb=$this->em->createQueryBuilder();
$qb->select('category.id industry_id,category.name industry_name,group_concat(category.name)')
但它没有这样做。
我也提到了symfony2: how to use group_concat in QueryBuilder
但#a.aitboudad提供的所有链接都是404.有人可以给我链接或其他事情吗?
感谢
答案 0 :(得分:6)
您需要创建自己的Doctrine函数才能使用GROUP_CONCAT;
config.yml;
orm:
dql:
string_functions:
GROUP_CONCAT: Your\Bundle\DQL\GroupConcat
您\捆绑\ DQL \ GroupConcat.php;
(来源:https://github.com/beberlei/DoctrineExtensions/blob/master/src/Query/Mysql/GroupConcat.php)
use Doctrine\ORM\Query\Lexer;
use Doctrine\ORM\Query\AST\Functions\FunctionNode;
class GroupConcat extends FunctionNode
{
public $isDistinct = false;
public $expression = null;
public function getSql(\Doctrine\ORM\Query\SqlWalker $sqlWalker)
{
return 'GROUP_CONCAT(' .
($this->isDistinct ? 'DISTINCT ' : '') .
$this->expression->dispatch($sqlWalker) .
')';
}
public function parse(\Doctrine\ORM\Query\Parser $parser)
{
$parser->match(Lexer::T_IDENTIFIER);
$parser->match(Lexer::T_OPEN_PARENTHESIS);
$lexer = $parser->getLexer();
if ($lexer->isNextToken(Lexer::T_DISTINCT)) {
$parser->match(Lexer::T_DISTINCT);
$this->isDistinct = true;
}
$this->expression = $parser->SingleValuedPathExpression();
$parser->match(Lexer::T_CLOSE_PARENTHESIS);
}
}
然后在您的查询构建器(或DQL)中;
$qb->select('GROUP_CONCAT(category.name)');