Доктрина ЛЕВАЯ функция mysql - PullRequest
0 голосов
/ 18 марта 2012

как я могу использовать с доктриной 2 левую функцию mysql?Запрос должен выглядеть примерно так:

SELECT LEFT(myfield, N) FROM mytable

Ответы [ 2 ]

2 голосов
/ 19 марта 2012

Вы можете реализовать это самостоятельно, например this .

0 голосов
/ 31 октября 2017
<?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));
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...