Задать вопрос

Положительно ли скажется на производительности перевод бд на utf8mb4 и удаление из after_connect_d7.php соответствующих директив?

В настройках mariadb-server:
character-set-server  = utf8
collation-server      = utf8_unicode_ci


В общем, utf8mb3.

А в файле bitrix/php_interface/after_connect_d7.php:
$this->queryExecute("SET NAMES 'utf8mb4'");
$this->queryExecute("SET collation_connection = 'utf8mb4_unicode_ci'");


Правильнее ли будет создать базу с настройками:
character-set-server  = utf8mb4
collation-server      = utf8mb4_unicode_ci


и удалить соответствующие вышеприведённые строчки из файла after_connect_d7.php ?

Верно ли я понимаю, что "конвертация" кодировки "на лету" средствами php отъедает существенно процессорное время?

(поломку базы и отображения на сайте в данном случае исключаем из рассмотрения).
  • Вопрос задан
  • 707 просмотров
Подписаться 3 Простой 1 комментарий
Решения вопроса 1
ipatiev
@ipatiev Куратор тега PHP
Потомок старинного рода Ипатьевых-Колотитьевых
Нет, неверно.

character-set-server и collation-server вообще ни на что не влияют. А только задают умолчания, если при создании БД и таблиц ленивый программист не указал кодировку. Поэтому трогать их нет смысла вообще.

Добавлять utf8mb4 в соединение также бессмысленно, если сами данные в utf8. Расширенные символы она всё равно сохранить не сможет.
И наоборот - если таблицы в utf8mb4, то указывать её при соединении надо в обязательном порядке. Не потому что вдруг "конвертация на лету" а потому что если соединение будет utf8, то расширенные символы клиент не получит.

(В теории, всё может работать нормально и без установки utf8mb4 для соединения, поскольку она в пыхе в какой-то момент начала использоваться по умолчанию, но лучше всё-таки задавать явно)
Ответ написан
Комментировать
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы