Преобразовать кодировку в utf8 для базы MySQL

Переконвертировать все таблицы в базе данных MYSQL из любой кодировки в utf8_general_ci очень просто, если использовать готовый скрипт и учесть некоторые нюансы.

Cкачать PHP-cкрипт.

Не забываетеделать резервную копию базы перед началом преобразований!

Как работает скрипт

С помощью скрипта вы быстро переконвертируете таблицу в любую кодировку. Принцип его работы прост - Для каджого поля, в каждой таблицы вашей БД сперва выполняется перевод в бинарный тип, а затем уже устанавливается новая кодировка:
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)

  1. Напишите первый комментарий
*Комментарий будет опубликован после проверки модератором

Похожие статьи

Решение ошибки Field 'id' doesn't have a default value

Примеры запросов

Преобразовать кодировку в utf8 для базы MySQL

Наш сайт использует куки, нажмите «ОК» если вы не против
OK