0

how can I use with doctrine 2 the LEFT function of mysql? The query should look something like

SELECT LEFT(myfield, N) FROM mytable
Your Common Sense
  • 156,878
  • 40
  • 214
  • 345
Stefano
  • 3,213
  • 9
  • 60
  • 101

1 Answers1

1
<?php

use Doctrine\ORM\Query\AST\Functions\FunctionNode;
use Doctrine\ORM\Query\Lexer;

/**
 * JsonbExistence ::= "LEFT('a', 'b')"
 *
 * This will be converted to: "LEFT('a', 'b')"
 *
 */
class LeftFunction extends FunctionNode
{

    public $column = null;
    public $regexp = null;

    public function parse(\Doctrine\ORM\Query\Parser $parser)
    {
        $parser->match(Lexer::T_IDENTIFIER);
        $parser->match(Lexer::T_OPEN_PARENTHESIS);
        $this->column = $parser->ArithmeticPrimary();
        $parser->match(Lexer::T_COMMA);
        $this->regexp = $parser->ArithmeticPrimary();
        $parser->match(Lexer::T_CLOSE_PARENTHESIS);
    }

    public function getSql(\Doctrine\ORM\Query\SqlWalker $sqlWalker)
    {
        return sprintf('LEFT(%s, %s)', $this->column->dispatch($sqlWalker), $this->regexp->dispatch($sqlWalker));
    }
}
MakoBuk
  • 464
  • 2
  • 8
  • 18