Подтвердить что ты не робот

Преобразование базы данных MySQL с латинского в UTF-8

Я конвертирую веб-сайт из ISO в UTF-8, поэтому мне также нужно преобразовать базу данных MySQL.

В Интернете я читаю различные решения, я не знаю, какой из них выбрать.

Мне действительно нужно преобразовать мои столбцы varchar в двоичные, а затем в UTF-8:

ALTER TABLE t MODIFY col BINARY(150);
ALTER TABLE t MODIFY col CHAR(150) CHARACTER SET utf8;

Для каждого столбца каждой таблицы каждой базы данных требуется много времени.

У меня есть 10 баз данных, каждая из которых содержит по 20 таблиц, с 2 - 3 столбцами varchar (2 запроса в каждом столбце), это дает мне около 1000 запросов для записи! Как это сделать?

Решено: Я отправляю код, который я использовал:

PASSWORD=""
db=$1

mysqldump --password=$PASSWORD --set-charset --skip-set-charset --add-drop-table --databases "$db" > /home/dev/backup/bdd.sql

QUERY="ALTER DATABASE \`$db\` DEFAULT CHARACTER SET utf8;"
mysql --password=$PASSWORD --database "$db" -e "$QUERY"

mysql --password=$PASSWORD --default-character-set=utf8 < /home/dev/backup/bdd.sql

Подробнее см. ниже.

4b9b3361

Ответ 1

Вы можете сделать это очень легко, используя дамп. Создайте дамп с помощью

mysqldump --skip-opt --set-charset --skip-set-charset 

Затем создайте другую базу данных, установите свой набор символов по умолчанию на UTF-8, а затем загрузите свою дамп обратно:

mysql --default-character-set=<your iso encoding>

Основная идея заключается в создании дампа без каких-либо признаков кодирования данных.
Таким образом, при создании времени кодировка таблицы наследуется от кодировки базы данных и устанавливается в UTF-8. И с --default-character-set мы говорим MySQL, чтобы автоматически перекодировать наши данные.

Ответ 2

Я использую mysqldump Ver 10.11 Distrib. 5.0.77

По какой-то причине создавать опции Engine и auto_increment были опущены. Это вызвало множество ошибок вставки, потому что auto_increment не был включен в поля первичных ключей.

Это сработало для меня. Я использую --opt и используя sed для удаления кодировки из sql файла.

mysqldump -p --opt --skip-set-charset --add-drop-table dbname > /tmp/dbname.sql
sed -i 's/DEFAULT CHARSET=latin1//g' /tmp/dbname.sql 
ALTER DATABASE dbname DEFAULT CHARACTER SET utf8 DEFAULT COLLATE utf8_danish_ci;
mysql -p --default-character-set=utf8 db < /tmp/dbname.sql 

Ответ 3

mysqldump --opt --skip-set-charset --default-character-set='latin1' -u root -p revive_adserver --result-file='dump.sql'

vim dump.sql

:%s/latin1/utf8/gi

:wq

mysql -u root -p

ALTER DATABASE revive_adserver CHARACTER SET utf8;

\q

mysql -D revive_adserver -u root -p < dump.sql