出于某种原因,我需要在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();
正在运作。有什么想法吗?
答案 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'
答案 2 :(得分:0)
这不是Doctrine问题,你必须将表校对更改为二进制,然后区分大小写才有效
改变表并改变这个
CHARSET = utf8 COLLATE = utf8_general_ci
到这个
CHARSET = utf8 COLLATE = utf8_bin