sql >> Databasteknik >  >> RDS >> Mysql

Fel vid användning av anpassad DQL-funktion med Doctrine och Symfony2

Efter flera letande har jag äntligen hittat lösningen. Jag hade två problem:för det första var min analysfunktion fel, för det andra anropade jag en SQL-funktion i min orderBy (tack Cerad ).

Så här är min korrekta klass:

namespace Ypok\YPoliceBundle\DQL;

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

class CastFunction extends FunctionNode
{
    public $firstDateExpression = null;
    public $unit = null;    

    public function parse(\Doctrine\ORM\Query\Parser $parser)
    {
        $parser->match(Lexer::T_IDENTIFIER);
        $parser->match(Lexer::T_OPEN_PARENTHESIS);
        $this->firstDateExpression = $parser->StringPrimary();

        $parser->match(Lexer::T_AS);

        $parser->match(Lexer::T_IDENTIFIER);
        $lexer = $parser->getLexer();
        $this->unit = $lexer->token['value'];

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

    public function getSql(\Doctrine\ORM\Query\SqlWalker $sqlWalker)
    {
        return sprintf('CAST(%s AS %s)',  $this->firstDateExpression->dispatch($sqlWalker), $this->unit);
    }
}

Och nu kan jag perfekt använda SQL-funktionen 'CAST' i mitt arkiv:

$qb = $this->_em->createQueryBuilder();
$qb->select('d, CAST(d.myField AS UNSIGNED) AS sortx')
   ->from('\Test\MyBundle\Entity\MyEntity', 'd')
   ->orderBy('sortx', 'ASC')

return $qb->getQuery()->getResult();

Med vänlig hälsning



  1. Hur får man veckodagens namn från ett datum?

  2. VARCHAR som främmande nyckel/primärnyckel i databasen bra eller dåligt?

  3. Anslut din ASP.NET kärnapplikation till en lokal instans av SQLServer

  4. Visa alla aktuella lås från get_lock