php - LEFT 主义 mysql 函数

标签 php mysql symfony doctrine-orm

如何使用学说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));
    }
}

关于php - LEFT 主义 mysql 函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9761748/

相关文章:

php - 改变随机句子的顺序

php - (403) 当我调用 Google_Service_Analytics_Profile 对象的插入时,您的项目无权访问此功能

java - 适合电子医疗系统的工具和技术?

php - ZF2 表单的 CSRF 即使使用无效值也会进行验证

mysql - 尝试按计数获取 MySql 订单,但每个只获取 1 个

mysql - 年龄计算小数位错误

mysql - 计算来自不同sql表的同名列

symfony2 缓存清除 --env=prod 不打印任何内容

symfony - 使用单选按钮设置 ChoiceType 中的默认数据

php - Symfony2 : Left Join producing wrong query