Doctrine2区分大小写的查询

时间:2012-08-26 11:05:10

标签: doctrine-orm case-sensitive

出于某种原因,我需要在MySql + doctrine中查询“区分大小写”2.是否可能?

既不

$em->find('UserEn', 'Bob')

,也不

$q = $this->em->createQuery('select u from UserEn u where u.name = :name');
$q->setParameter('name', 'Bob');
$result = $q->getResult();

正在运作。有什么想法吗?

3 个答案:

答案 0 :(得分:11)

也许您正在使用以“_ci”结尾的MySQL排序规则,例如“utf8_general_ci”。 “ci”代表“不区分大小写”。 如果是这种情况,那么它不是Doctrine问题,而是MySQL问题。

请参阅http://dev.mysql.com/doc/refman/5.0/en/case-sensitivity.html

“默认字符集和排序规则是latin1和latin1_swedish_ci,因此默认情况下非二进制字符串比较不区分大小写。”

答案 1 :(得分:2)

对于那些无法更改其数据库归类的人,您可以使用BINARY运算符以强制符合条件的区分大小写。

  

BINARY运算符将其后面的字符串转换为二进制字符串。   这是一种强制比较逐字节完成的简单方法   而不是逐字逐句。 BINARY也会导致尾随空格   重要的。

有关详细信息,请参阅MySQL BINARY Operator

要在Doctrine DQL中启用BINARY运算符,您可以安装Doctrine Extensions library。 或者像这样创建自己的二进制字符串函数。

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

class Binary extends FunctionNode
{
    private $stringPrimary;

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

        $this->stringPrimary = $parser->StringPrimary();

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

    public function getSql(\Doctrine\ORM\Query\SqlWalker $sqlWalker)
    {
        return 'BINARY('.$sqlWalker->walkSimpleArithmeticExpression($this->stringPrimary).')';
    }
}

接下来,您需要在您的学说配置中注册binary字符串函数。您可以在配置设置中执行此操作,或者根据需要添加它。

$em->getConfiguration()->addCustomStringFunction('binary', 'DoctrineExtensions\\Query\\Mysql\\Binary');

然后您就可以在DQL中使用binary(...)函数了。

$q = $em->createQuery('select u from UserEn u where binary(u.name) = :name');
echo $q->getSQL();
/* SELECT ... FROM ... WHERE BINARY(u0_.name) = ? */

要使用Symfony框架添加binary字符串函数,请在config.yml文件中更改doctrine.orm.entity_managers.%entity_manager%.dql设置。

doctrine:
    orm:
      #...
      entity_managers:
          #...
          default:
              #...
              dql:
                  #...
                  string_functions:
                      #...
                      binary: 'DoctrineExtensions\Query\Mysql\Binary'

有关详细信息,请参阅Symfony Doctrine Configuration Documentation

答案 2 :(得分:0)

这不是Doctrine问题,你必须将表校对更改为二进制,然后区分大小写才有效 改变表并改变这个 CHARSET = utf8 COLLATE = utf8_general_ci
到这个 CHARSET = utf8 COLLATE = utf8_bin