sql >> Databáze >  >> RDS >> Mysql

Doctrine 2 DQL MySQL ekvivalentní ROUND()?

Musíte implementovat vlastní funkci DQL za to.

Některé příklady jsou v DoctrineExtensions .

Můžete to implementovat následovně:

<?php

namespace MyApp\DQL;

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

class Round extends FunctionNode
{
    private $arithmeticExpression;

    public function getSql(SqlWalker $sqlWalker)
    {

        return 'ROUND(' . $sqlWalker->walkSimpleArithmeticExpression(
            $this->arithmeticExpression
        ) . ')';
    }

    public function parse(\Doctrine\ORM\Query\Parser $parser)
    {

        $lexer = $parser->getLexer();

        $parser->match(Lexer::T_IDENTIFIER);
        $parser->match(Lexer::T_OPEN_PARENTHESIS);

        $this->arithmeticExpression = $parser->SimpleArithmeticExpression();

        $parser->match(Lexer::T_CLOSE_PARENTHESIS);
    }
}

Poté jej můžete zaregistrovat v konfiguraci při bootstrapování ORM:

$config = new \Doctrine\ORM\Configuration();

$config->addCustomNumericFunction('ROUND', 'MyApp\DQL\Round');


  1. Jak nainstalovat sqlcmd &bcp na SUSE

  2. MySQL - ignorovat chybu vložení:duplicitní záznam

  3. jak exportovat data z tabulky protokolu do těla e-mailu v oracle

  4. Tři hlavní trendy ovlivňující DBA odpovědné za monitorování SQL Serveru