I am converting a website from ISO to UTF-8, so I need to convert the MySQL database too.
On the Internet, I read various solutions, I don't know which one to choose.
Do I really need to convert my varchar columns to binary, then to UTF-8 like that:
ALTER TABLE t MODIFY col BINARY(150); ALTER TABLE t MODIFY col CHAR(150) CHARACTER SET utf8;
It takes a long time to do that for each column, of each table, of each database.
I have 10 databases, with 20 tables each, with around 2 - 3 varchar columns (2 queries each column), this gives me around 1000 queries to write! How to do it?
Resolved : I post the code that I have used:
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
See the answer below for more information.
To change the character set encoding to UTF-8 for the database itself, type the following command at the mysql> prompt. Replace dbname with the database name: Copy ALTER DATABASE dbname CHARACTER SET utf8 COLLATE utf8_general_ci; To exit the mysql program, type \q at the mysql> prompt.
Similarly, here's the command to change character set of MySQL table from latin1 to UTF8. Replace table_name with your database table name. mysql> ALTER TABLE table_name CONVERT TO CHARACTER SET utf8 COLLATE utf8_unicode_ci; Hopefully, the above tutorial will help you change database character set to utf8mb4 (UTF-8).
You can change the default with an alter table set default charset but that won't change the charset of the existing columns. To change that you need to use a alter table modify column . Changing the charset of a column only means that it will be able to store a wider range of characters.
You can do that very easily using a dump. Make a dump using
mysqldump --skip-opt --set-charset --skip-set-charset
Then create another database, set its default character set to UTF-8 and then load your dump back with:
mysql --default-character-set=<your iso encoding>
The main idea is to make a dump without any sign of data encoding.
So, at create time, the table's encoding would be inherit from the database encoding and set to UTF-8. And with --default-character-set
we tell MySQL to recode our data automatically.
I'm using mysqldump Ver 10.11 Distrib 5.0.77
For some reason create options Engine and auto_increment was omitted. This caused a lot of insert errors, because auto_increment was gone on primary key fields.
This worked for me. I'm using --opt and using sed to remove charset from sql file.
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
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With