mysql:configure_utf8mb4
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
mysql:configure_utf8mb4 [2016/07/03 10:06] – peter | mysql:configure_utf8mb4 [2020/07/15 09:30] (current) – external edit 127.0.0.1 | ||
---|---|---|---|
Line 5: | Line 5: | ||
These instructions show how to convert the entire database to be **utf8mb4**. | These instructions show how to convert the entire database to be **utf8mb4**. | ||
- | Back up your data first. | + | **IMPORTANT: |
- | ===== Update Database ===== | + | The following instructions assume that a case-sensitive database is required throughout. |
- | Update | + | * For case-sensitive text set the character set to **utf8mb4_bin**. |
+ | * For case-insensitive text, the character set can be set to **utf8mb4_unicode_ci** instead. | ||
- | For case-sensitive text set the character set to **utf8mb4_bin**. | ||
- | <code mysql> | ||
- | ALTER DATABASE `mydatabase` CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_bin; | ||
- | </ | ||
+ | ===== Back up your data ===== | ||
- | For case-insensitive text, then the character set can be set to **utf8mb4_unicode_ci** instead. | + | Before making any change to a database it is always recommended that a full backup of the database is taken. |
+ | |||
+ | |||
+ | ===== Update Database ===== | ||
+ | |||
+ | Update the default | ||
<code mysql> | <code mysql> | ||
- | ALTER DATABASE `mydatabase` CHARACTER SET utf8mb4 COLLATE | + | ALTER DATABASE `mydatabase` CHARACTER SET utf8mb4 COLLATE |
</ | </ | ||
- | + | ||
===== Update Tables ===== | ===== Update Tables ===== | ||
Line 30: | Line 34: | ||
<code mysql> | <code mysql> | ||
- | ALTER TABLE `mytable1` DEFAULT CHARACTER SET utf8mb4 COLLATE | + | ALTER TABLE `mytable1` DEFAULT CHARACTER SET utf8mb4 COLLATE |
</ | </ | ||
- | |||
- | |||
===== Update Table Columns ===== | ===== Update Table Columns ===== | ||
Line 40: | Line 42: | ||
<code mysql> | <code mysql> | ||
- | ALTER TABLE `mytable1` CHANGE `mycolumn` `mycolumn` VARCHAR(64) CHARACTER SET utf8mb4 COLLATE | + | ALTER TABLE `mytable1` CHANGE `mycolumn` `mycolumn` VARCHAR(64) CHARACTER SET utf8mb4 COLLATE |
</ | </ | ||
- | + | Ensure | |
- | Now obviously | + | |
If on the other hand you just want to change the entire the entire table at once, you can do: | If on the other hand you just want to change the entire the entire table at once, you can do: | ||
<code mysql> | <code mysql> | ||
- | ALTER TABLE `mytable1` CONVERT TO CHARACTER SET utf8mb4 COLLATE | + | ALTER TABLE `mytable1` CONVERT TO CHARACTER SET utf8mb4 COLLATE |
</ | </ | ||
Line 70: | Line 71: | ||
If you're using InnoDB on MySQL 5.6.3 or higher you can enable **innodb_large_prefix** in your MySQL config file (more information in manual http:// | If you're using InnoDB on MySQL 5.6.3 or higher you can enable **innodb_large_prefix** in your MySQL config file (more information in manual http:// | ||
- | | + | |
- | | + | |
+ | | ||
<code mysql> | <code mysql> | ||
Line 77: | Line 79: | ||
</ | </ | ||
- | |||
Then recreate it with the offending column(s) limited to 191: | Then recreate it with the offending column(s) limited to 191: | ||
Line 94: | Line 95: | ||
+ | How does one find the offending index? | ||
+ | |||
+ | <code mysql> | ||
+ | mysql> DROP INDEX foo_1234 on foo; | ||
+ | Query OK, 0 rows affected (0.00 sec) | ||
+ | Records: 0 Duplicates: 0 Warnings: 0 | ||
+ | mysql> ALTER TABLE foo CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_bin; | ||
+ | Query OK, 0 rows affected (0.11 sec) | ||
+ | Records: 0 Duplicates: 0 Warnings: 0 | ||
+ | CREATE INDEX foo_1234 ON foo (`baz`(191)); | ||
+ | </ | ||
+ | |||
+ | ===== Additional Notes and Considerations ===== | ||
+ | |||
+ | If a column is not being used for search and case insensitivity isn't an issue, instead of using CHAR or VARCHAR, I suggest using BINARY and VARBINARY. | ||
+ | |||
+ | Additionally instead of using TEXT, use BLOB, for the same reasons, but also realize the same limitations apply, such as no fulltext searching. | ||
+ | |||
+ | In summation, if you don't need case sensitivity and you don't need fulltext search, consider BINARY, VARBINARY, and BLOB over CHAR, VARCHAR, and TEXT, it'll be a lot easier to deal with when it comes to Unicode. | ||
+ | |||
+ | You can learn more about this on my MySQL performance, | ||
+ | |||
+ | |||
+ | |||
+ | ===== Database Connections ===== | ||
+ | |||
+ | Depending on your programming language, you may need to specify when connecting which chartype to use (you can also, in most cases, specify this on configuration, | ||
+ | |||
+ | <code mysql> | ||
+ | SET NAMES utf8mb4; | ||
+ | </ | ||
+ | |||
+ | |||
+ | |||
+ | ===== Configuration ===== | ||
+ | |||
+ | You can edit your my.cnf (or my.ini on Windows) and make these changes to the appropriate sections of the configuration file (applicable to MySQL 5.6, older versions may need adjusted configuration): | ||
+ | |||
+ | <code mysql> | ||
+ | [client] | ||
+ | default-character-set = utf8mb4 | ||
+ | |||
+ | [mysql] | ||
+ | default-character-set = utf8mb4 | ||
+ | |||
+ | [mysqld] | ||
+ | character-set-client-handshake = FALSE | ||
+ | character-set-server = utf8mb4 | ||
+ | collation-server = utf8mb4_bin | ||
+ | </ |
mysql/configure_utf8mb4.1467540373.txt.gz · Last modified: 2020/07/15 09:30 (external edit)