教义 ORM 中的 Substring_index 函数

Substring_index function in doctrine ORM(教义 ORM 中的 Substring_index 函数)
本文介绍了教义 ORM 中的 Substring_index 函数的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我必须在 symfony 2 的学说 ORM 中使用 SUBSTRING_INDEX 函数.我该怎么做?现在在查询中使用它会给我未定义的函数错误:

I have to use SUBSTRING_INDEX function in doctrine ORM in symfony 2. How can I do this? Right now using it inside the query gives me undefined function error:

[Syntax Error] line 0, col 299: Error: Expected known function, got 'SUBSTRING_INDEX'

我使用这个函数来获取第一个数字,例如:

I use this function to get the first number from, for example:

11.48.205.1

我该如何解决这个问题?

How can I solve this?

推荐答案

这是代表 SUBSTRING_INDEX 函数的类(不要忘记更新命名空间).

Here is class that represent SUBSTRING_INDEX function (don't forget to update namespace).

<?php

namespace SadFunctions;

use DoctrineORMQueryASTFunctionsFunctionNode;
use DoctrineORMQueryLexer;
use DoctrineORMQuerySqlWalker;
use DoctrineORMQueryParser;

/**
 * "SUBSTRING_INDEX" "(" ArithmeticPrimary "," ArithmeticPrimary "," ArithmeticPrimary ")"
 *
 * @author  Andrey Stepanov <stepashka@gmail.com>
 */
class SubstringIndexFunction extends FunctionNode
{
    public $str = null;
    public $delim = null;
    public $count = null;

    /**
     * @override
     */
    public function getSql(SqlWalker $sqlWalker)
    {
        return 'SUBSTRING_INDEX(' .
            $this->str->dispatch($sqlWalker) . ', ' .
            $this->delim->dispatch($sqlWalker) . ', ' .
            $this->count->dispatch($sqlWalker) .
        ')';
    }

    /**
     * @override
     */
    public function parse(Parser $parser)
    {
        $parser->match(Lexer::T_IDENTIFIER);
        $parser->match(Lexer::T_OPEN_PARENTHESIS);
        $this->str = $parser->ArithmeticPrimary();
        $parser->match(Lexer::T_COMMA);
        $this->delim = $parser->ArithmeticPrimary();
        $parser->match(Lexer::T_COMMA);
        $this->count = $parser->ArithmeticPrimary();
        $parser->match(Lexer::T_CLOSE_PARENTHESIS);
    }
}

创建实体管理器前需要先注册:

You need to register it before creating entity manager:

$config->addCustomStringFunction('SUBSTRING_INDEX', 'SadFunctionsSubstringIndexFunction');
/* ... */
$entityManager = EntityManager::create($conn, $config);

做完之后会得到如下结果:

After you do it you'll get the following results:

echo $entityManager->createQuery("SELECT p FROM SadSchemaAbstractPageAny as p WHERE SUBSTRING_INDEX(p.name,'a',1) = 'P'")->getSQL();
// Output: SELECT p0_.id AS id_0, p0_.name AS name_1, p0_.type AS type_2 FROM page p0_ WHERE (SUBSTRING_INDEX(p0_.name, 'a', 1) = 'P')

这篇关于教义 ORM 中的 Substring_index 函数的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Convert JSON integers and floats to strings(将JSON整数和浮点数转换为字符串)
in php how do I use preg replace to turn a url into a tinyurl(在php中,如何使用preg替换将URL转换为TinyURL)
all day appointment for ics calendar file wont work(ICS日历文件的全天约会不起作用)
trim function is giving unexpected values php(Trim函数提供了意外的值php)
Basic PDO connection to MySQL(到MySQL的基本PDO连接)
PHP number_format returns 1.00(Php number_Format返回1.00)