symfony2:在 QueryBuilder(Doctrine) 中使用 group_concat [英] symfony2: Using group_concat in QueryBuilder(Doctrine)
问题描述
我正在尝试使用 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屋!