Mysql
 sql >> база данни >  >> RDS >> Mysql

Doctrine 2 DQL MySQL еквивалентен на ROUND()?

Трябва да внедрите персонализирана DQL функция за това.

Има някои примери в DoctrineExtensions .

Можете да го приложите по следния начин:

<?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);
    }
}

След това можете да го регистрирате в конфигурацията, докато стартирате ORM:

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

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


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Пребройте броя на появяванията на низ в поле VARCHAR?

  2. Как да получа необработена, компилирана SQL заявка от SQLAlchemy израз?

  3. Вложена заявка в node js с помощта на mysql

  4. Не може да се изпълни MySQL съхранена процедура от Java

  5. Ruby:mysql2-Gem не работи (Mac OS X Snow Leopard, Ruby 1.9.2)