2015-07-14 13 views
7

Tôi cố gắng để sử dụng GROUP_CONCAT() trong học thuyết sử dụng querybuilder()symfony2: Sử dụng group_concat trong QueryBuilder (Học thuyết)

Tôi cố gắng này

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

nhưng nó không làm việc theo cách này.

tôi được ám symfony2: how to use group_concat in QueryBuilder

nhưng tất cả các liên kết được cung cấp bởi # a.aitboudad sẽ 404. ai có thể cho tôi liên kết hoặc một cái gì đó để làm điều đó?

cảm ơn

+1

Học thuyết không biết "group_concat" là gì, vì vậy bạn phải dạy Doctrine phải làm gì với nó. Tài liệu tại http://doctrine-orm.readthedocs.org/en/latest/cookbook/dql-user-defined-functions.html – Koalabaerchen

Trả lời

5

Bạn sẽ cần tạo chức năng Doctrine của riêng bạn để sử dụng GROUP_CONCAT;

config.yml;

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

\ Bundle \ DQL \ GroupConcat.php của bạn;

(nguồn: 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); 
} 
} 

Sau đó, trong xây dựng truy vấn của bạn (hoặc DQL);

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

Nó phải là 'string_functions' không phải là' concat_functions'. Xem câu trả lời này: http://stackoverflow.com/questions/10850345/symfony2-how-to-use-group-concat-in-querybuilder –

+0

Có thats đúng không concat_functions. –

Các vấn đề liên quan