MySQL/MariaDB中如何支持全部的Unicode( 三 )


第 3 步:修改数据库、表和列
将数据库、表和列的字符集和排序规则属性更改为使用 utf8mb4。
# For each database:ALTER DATABASE database_name CHARACTER SET = utf8mb4 COLLATE = utf8mb4_unicode_ci;# For each table:ALTER TABLE table_name CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;# For each column:ALTER TABLE table_name CHANGE column_name column_name VARCHAR(191) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;# (不要盲目复制粘贴!具体的语句取决于列类型、最大长度和其他属性 。上面这行只是一个`VARCHAR`列的例子 。)# 或者modefy语句ALTER TABLE table_name MODIFY column_name VARCHAR(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;
第 4 步:检查列和索引键的最大长度
这可能是整个升级过程中最乏味的部分 。
从 utf8 转换为 utf8mb4 时,列或索引键的最大长度以字节为单位不变 。因此,它在字符方面更小,因为字符的最大长度现在是四个字节而不是三个字节 。
例如,TINYTEXT 列最多可容纳 255 个字节,这与 85 个三字节字符或 63 个四字节字符相关 。假设你有一个使用 utf8 的 TINYTEXT 列,但必须能够包含 63 个以上的字符 。鉴于此要求,无法将此列转换为 utf8mb4,除非还将数据类型更改为更长的类型,例如 TEXT — 因为如果你尝试用四字节字符填充它,将只能输入 63 个字符,但不能更多 。
索引键也是如此 。InnoDB 存储引擎的最大索引长度为 767 字节,因此对于 utf8 或 utf8mb4 列,您最多可以分别索引 255 或 191 个字符 。如果您当前有索引长度超过 191 个字符的 utf8 列,则在使用 utf8mb4 时需要索引较少数量的字符 。(因此,我不得不将一些索引的 VARCHAR(255) 列更改为 VARCHAR(191) 。)
第 5 步:修改连接、客户端和服务器字符集
在应用程序代码中,将连接字符集设置为 utf8mb4 。这可以通过简单地用 SET NAMES utf8mb4 替换 SET NAMES utf8 来完成 。同时排序规则也要对应修改,例如 SET NAMES utf8 COLLATE utf8_unicode_ci 变为 SET NAMES utf8mb4 COLLATE utf8mb4_unicode_ci 。
确保同时设置客户端和服务器字符集 。
MySQL 配置文件 (/etc/my.cnf) 中有以下内容:
[client]default-character-set = utf8mb4[mysql]default-character-set = utf8mb4[mysqld]character-set-client-handshake = FALSEcharacter-set-server = utf8mb4collation-server = utf8mb4_unicode_ci
第 6 步:修复优化所有表( Repair and optimize )
升级 MySQL 服务器并进行上述必要更改后,请确保修复和优化所有数据库和表 。否则可能会遇到奇怪的错误,即使没有错误被抛出 。
可以为要修复和优化的每个表运行以下 MySQL 查询:
# For each tableREPAIR TABLE table_name;OPTIMIZE TABLE table_name;
该工作,可以使用命令行 mysqlcheck 实用程序一次性轻松完成:
$ mysqlcheck -u root -p --auto-repair --optimize --all-databases
这将提示输入root用户的密码,之后将修复和优化所有数据库中的所有表 。

参考
主要参考翻译自:How to support full Unicode in MySQL databases,欢迎阅读原文 。
【MySQL/MariaDB中如何支持全部的Unicode】到此这篇关于MySQL/MariaDB中如何支持全部的Unicode的文章就介绍到这了,更多相关MySQL/MariaDB支持Unicode内容请搜索趣讯吧以前的文章或继续浏览下面的相关文章希望大家以后多多支持趣讯吧!

推荐阅读