У параметра Symfony 2/Doctrine, определяемого пользователем DQL, есть ограничение длины строки?
Я создал свою собственную функцию DQL для Doctrine DQL:
class Translate extends FunctionNode {
public $field;
public function getSql(SqlWalker $sqlWalker) {
$query = "TRANSLATE(" . $this->field->dispatch($sqlWalker) . ", 'àâäãáåÀÁÂÃÄÅçÇéèêëÉÈÊËîïìíÌÍÎÏñÑôöðòóÒÓÔÕÖùúûüÙÚÛÜýÿÝ', 'AAAAAAAAAAAACCEEEEEEEEIIIIIIIINNOOOOOOOOOOUUUUUUUUYYY')";
return $query;
}
public function parse(Parser $parser) {
$parser->match(Lexer::T_IDENTIFIER);
$parser->match(Lexer::T_OPEN_PARENTHESIS);
$this->field = $parser->StringPrimary();
$parser->match(Lexer::T_CLOSE_PARENTHESIS);
}
}
Кажется, что он хорошо работает при использовании.
Но если параметр string содержит более 307 символов, он не работает.
Ошибка отсутствует, но script заканчивается.
$query = $this->createQueryBuilder('...');
$query->addSelect("TRANSLATE('less than 307 chars')"); // working
$query->addSelect("TRANSLATE('more than 307 chars')"); // NOT working
Как я могу использовать более 307 символов?
Ответы
Ответ 1
Как уже объяснил wrikken, транслитерация должна выполняться с помощью iconv, так как это сохранит ваши ресурсы сервера.
здесь простая функция, которая транслитерирует (конвертирует не латинские символы в их ближайшие представления в латинской кодировке) строку.
function transliterateString($str)
{
$serverLocale = setlocale(LC_CTYPE, 0);
setlocale(LC_CTYPE, 'en_US.UTF8');
// transliterate the string using iconv
$str = iconv('UTF-8', 'ASCII//TRANSLIT//IGNORE', $str);
setlocale(LC_CTYPE, $serverLocale); // return the locale to what it was before
return $str;
}
Использование:
$string = "café";
echo $string;
echo transliterateString($string);
Выше будет выводиться ниже:
café
cafe