Преобразовать кодировку в 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. Напишите первый комментарий
*Комментарий будет опубликован после проверки модератором

[MODx] Генератор настроек MIGX

[MODx, MIGx] Документация на русском по MIGX

[MODX] Импорт и экспорт в MiniShop2. Реализация 1

[MODx] minishop2 tips

[JS] Маска для ввода телефона +7(___)___-__-__

[MODx, miniShop2] Генерация YML для выгрузки в маркет

Как включить HTTPS (SSL) в MODX - Подробная инструкция

[MODx] Подсказки по API

[OpenCart] Вывести на главную все категории с картинками

[MODx, MIGX] Примеры использования

[MODx] Сайт на обслуживании (выключить сайт)

Универсальная форма обратной связи — feedBackForm

[PHP, JSON] Пример перевода с помощью Yandex Translate API

[MODx, Gallery] Галерея. Вывести обложки альбомов и фотографии

Расширение свойств товаров minishop2

[Opencart] Вернуть английский язык, если вы его удалили

[OpenCart] Вывести модуль напрямую через контроллер

[MODx, Quip] Более рабочий вариант.

[MODX, MIGX] Вывести getImageList только если он не пустой

[MODX, MIGX] Тип поля "Список ресурсов" (resourcelist) с ограничением по родителю (parents)

Красивое адаптивное меню под pdoMenu

[MODx] Создать источник файлов

[MODx] Вывод tv-параметров в формате [название TV] - [значение TV]

[PHP] Простое логирование

[MODX] Вывести список всех опций MiniShop2

Все записи