Doctrine LEFT mysql function


Doctrine LEFT mysql function

如何与条令2一起使用mysql的LEFT函数?查询应该看起来像

SELECT LEFT(myfield, N) FROM mytable
<?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));
    }
}