gpt4 book ai didi

symfony2 : Using group_concat in QueryBuilder(Doctrine)

转载 作者:行者123 更新时间:2023-12-04 12:06:36 25 4
gpt4 key购买 nike

我正在尝试使用 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。谁能给我链接或做些什么?

谢谢

最佳答案

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

config.yml;

  orm:
dql:
string_functions:
GROUP_CONCAT: Your\Bundle\DQL\GroupConcat

你的\Bundle\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)');

关于symfony2 : Using group_concat in QueryBuilder(Doctrine),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31401082/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com