簡體   English   中英

自定義原則DQL功能

[英]Custom Doctrine DQL Function

我是Symfony的新手,所以也許我的問題很愚蠢,但這是:

我試圖定義一個自定義的DQL函數,但無法正常工作。

的PHP

namespace MsfBundle\AST\Functions;


use Doctrine\ORM\Query\Lexer;

class Geo extends \Doctrine\ORM\Query\AST\Functions\FunctionNode
{
    /**
     * @var \Doctrine\ORM\Query\AST\ComparisonExpression
     */
    private $latitude;
    /**
     * @var \Doctrine\ORM\Query\AST\ComparisonExpression
     */    
    private $longitude;

    /**
     * Parse DQL Function
     * 
     * @param \Doctrine\ORM\Query\Parser $parser 
     */
    public function parse(\Doctrine\ORM\Query\Parser $parser)
    {
        $parser->match(Lexer::T_IDENTIFIER);
        $parser->match(Lexer::T_OPEN_PARENTHESIS);
        $this->latitude = $parser->ComparisonExpression();
        $parser->match(Lexer::T_COMMA);
        $this->longitude = $parser->ComparisonExpression();
        $parser->match(Lexer::T_CLOSE_PARENTHESIS);
    }

    /**
     * Get SQL 
     * 
     * @param \Doctrine\ORM\Query\SqlWalker $sqlWalker
     * @return string
     */
    public function getSql(\Doctrine\ORM\Query\SqlWalker $sqlWalker)
    {

    return sprintf('(6366*acos(cos(radians(%s))*cos(radians(`%s`))*cos(radians(`%s`) -radians(%s))+sin(radians(%s))*sin(radians(`%s`))))',
    $this->latitude->leftExpression->dispatch($sqlWalker),
    $this->latitude->rightExpression->dispatch($sqlWalker),
    $this->longitude->rightExpression->dispatch($sqlWalker), 
    $this->longitude->leftExpression->dispatch($sqlWalker),
    $this->latitude->leftExpression->dispatch($sqlWalker),
    $this->latitude->rightExpression->dispatch($sqlWalker));
    }
}

配置文件

doctrine:
#...
orm:
    auto_generate_proxy_classes: "%kernel.debug%"
    entity_managers:
        default:
            auto_mapping: true
            dql:
                numeric_functions:
                    geo :MsfBundle\AST\Functions\Geo

這就是我得到的:

致命錯誤:在3070行的/var/www/mcr/vendor/doctrine/orm/lib/Doctrine/ORM/Query/Parser.php中找不到類'MsfBundle \\ AST \\ Functions \\ Geo'

如果您有任何幫助我解決這個問題的方法,我將不勝感激。

謝謝 !

您在geo:MsfBundle \\ AST \\ Functions \\ Geo中缺少反斜線,應該是geo:\\ MsfBundle \\ AST \\ Functions \\ Geo。 似乎該類需要絕對引用。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM