symfony2:在 QueryBuilder(Doctrine) 中使用 group_concat [英] symfony2: Using group_concat in QueryBuilder(Doctrine)

查看:21
本文介绍了symfony2:在 QueryBuilder(Doctrine) 中使用 group_concat的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在尝试使用 querybuilder() 在学说中使用 GROUP_CONCAT()

I am trying to use GROUP_CONCAT() in doctrine using querybuilder()

我试过了

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

但它不是这样工作的.

我还参考了 symfony2:如何在 QueryBuilder 中使用 group_concat

但是#a.aitboudad 提供的所有链接都是 404.谁能给我链接或做些什么?

but all the link provided by #a.aitboudad are going 404. can anyone give me link or something to do it ?

谢谢

推荐答案

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

You will need to create your own Doctrine function to use GROUP_CONCAT;

config.yml;

config.yml;

  orm:
  dql:
    string_functions:
        GROUP_CONCAT: YourBundleDQLGroupConcat

你的BundleDQLGroupConcat.php;

YourBundleDQLGroupConcat.php;

(来源:https://github.com/beberlei/DoctrineExtensions/blob/master/src/Query/Mysql/GroupConcat.php)

 use DoctrineORMQueryLexer;
 use DoctrineORMQueryASTFunctionsFunctionNode;

 class GroupConcat extends FunctionNode
 {
public $isDistinct = false;
public $expression = null;

public function getSql(DoctrineORMQuerySqlWalker $sqlWalker)
{
    return 'GROUP_CONCAT(' .
        ($this->isDistinct ? 'DISTINCT ' : '') .
        $this->expression->dispatch($sqlWalker) .
    ')';
}

public function parse(DoctrineORMQueryParser $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)中;

Then in your query builder (or DQL);

  $qb->select('GROUP_CONCAT(category.name)');

这篇关于symfony2:在 QueryBuilder(Doctrine) 中使用 group_concat的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆