symfony2:在QueryBuilder中使用group_concat(Doctrine)

Sun*_*mar 7 symfony doctrine-orm

我试图使用querybuilder()在doctrine中使用GROUP_CONCAT()

我试过这个

   $qb=$this->em->createQueryBuilder();
   $qb->select('category.id industry_id,category.name industry_name,group_concat(category.name)')
Run Code Online (Sandbox Code Playgroud)

但它不是这样工作的.

我还提到了symfony2:如何在QueryBuilder中使用group_concat

但#a.aitboudad提供的所有链接都是404.有人可以给我链接或其他事情吗?

谢谢

Ste*_*B19 6

您需要创建自己的Doctrine函数才能使用GROUP_CONCAT;

config.yml;

  orm:
  dql:
    string_functions:
        GROUP_CONCAT: Your\Bundle\DQL\GroupConcat
Run Code Online (Sandbox Code Playgroud)

你\包\ 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);
}
}
Run Code Online (Sandbox Code Playgroud)

然后在您的查询构建器(或DQL)中;

  $qb->select('GROUP_CONCAT(category.name)');
Run Code Online (Sandbox Code Playgroud)