Переконвертировать все таблицы в базе данных MYSQL из любой кодировки в utf8_general_ci очень просто, если использовать готовый скрипт и учесть некоторые нюансы.
Не забываетеделать резервную копию базы перед началом преобразований!
Как работает скрипт
С помощью скрипта вы быстро переконвертируете таблицу в любую кодировку. Принцип его работы прост - Для каджого поля, в каждой таблицы вашей БД сперва выполняется перевод в бинарный тип, а затем уже устанавливается новая кодировка:
ALTER TABLE `modx_site_content` MODIFY `pagetitle` varchar(255) CHARACTER SET binary;
ALTER TABLE `modx_site_content` MODIFY `pagetitle` varchar(255) COLLATE utf8_general_ci;
Перед запуском можно указать нужную кодировку, по-умолчанию это utf8_general_ci.
Возможные ошибки
При выполнении скрипта может возникнуть ошибка: Column 'pagetitle' cannot be part of FULLTEXT index
Эта ошибка вызвана тем, что колонки с индексом FULLTEXT нельзя модифицировать этим способом. Для того чтобы эту проблему решить, понадобится отключить этот индекс у даных полей, а затем включить его снова.
Я это сделал достаточно топорным способом - сделал дамп базы и просто убрал строчки о добавлении этого индекса. Наверно, есть более изящный способ. Например, через PhpMyAdmin:
Если вы сталкнулись со сложностями во время работы со этим скриптом, напишите об этом в комментариях. Особенно ценно будет, если вы опишите как вы решили эти неожиданные проблемы.
Комментарии (0)
Не писать ответ