查字符集用 SHOW VARIABLES LIKE 'character_set%' 和 SHOW VARIABLES LIKE 'collation%';三参数 character_set_client/connection/results 必须一致;配置需在 [mysqld] 段设置并重启;云数据库改参数组;应用连接字符串要加 charset=utf8mb4。查当前字符集设置用什么命令直接连上 MySQL 后执行 SHOW VARIABLES LIKE 'character_set%'; 和 SHOW VARIABLES LIKE 'collation%';,这是最准的起点。别只看配置文件,运行时可能被客户端、连接层或表级设置覆盖。常见错误现象:建库时指定了 utf8mb4,但 character_set_client 还是 latin1,插入中文就变问号或乱码;或者 collation_server 是 utf8mb4_unicode_ci,但 collation_database 是 utf8mb4_general_ci,排序行为不一致。character_set_server 控制新库默认字符集,但不影响已有库character_set_client、character_set_connection、character_set_results 三者要一致,否则中间转码会丢数据MySQL 8.0 默认已是 utf8mb4,但老版本(如 5.6/5.7)默认还是 utf8(实际是 utf8mb3),不支持 emoji 和部分生僻汉字修改 my.cnf 配置的关键位置在哪不是所有段落都管用。必须在 [mysqld] 下写 character_set_server = utf8mb4 和 collation_server = utf8mb4_unicode_ci;[client] 和 [mysql] 段下加 default-character-set = utf8mb4(注意:MySQL 8.0+ 已弃用该选项,改用 charset = utf8mb4)。容易踩的坑:[mysqld] 里漏了 init_connect='SET NAMES utf8mb4',导致普通用户连接后没自动设对三件套;或者把配置写在 [mysqld_safe] 里,完全不生效。修改后必须重启 MySQL(systemctl restart mysqld),仅重载配置不够配置文件路径通常是 /etc/my.cnf 或 /etc/mysql/my.cnf,Docker 容器里得挂载进 /etc/mysql/conf.d/ 目录如果用云数据库(如阿里云 RDS),不能改 my.cnf,只能通过控制台参数组调整已有表和字段怎么批量转 utf8mb4不能只改库,得逐个改表和字段。先用 ALTER DATABASE db_name CHARACTER SET = utf8mb4 COLLATE = utf8mb4_unicode_ci; 改库,再对每张表执行 ALTER TABLE table_name CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;。 arXiv Xplorer ArXiv 语义搜索引擎,帮您快速轻松的查找,保存和下载arXiv文章。
相关推荐
wj3055853787 小时前
课程 9:模型测试记录与 Prompt 策略星寂樱易李8 小时前
iperf3 + Python-- 网络带宽、网速、网络稳定性qingfeng154158 小时前
企业微信机器人开发:如何实现自动化与智能运营?星星也在雾里8 小时前
PgBouncer 解决 PostgreSQL 连接数超限 + 可视化监控AI人工智能+电脑小能手9 小时前
【大白话说Java面试题 第65题】【JVM篇】第25题:谈谈对 OOM 的认识雨辰AI10 小时前
SpringBoot3 + 人大金仓读写分离 + 分库分表 + 集群高可用 全栈实战长城202410 小时前
关于MySql的ONLY_FULL_GROUP_BY问题常常有10 小时前
MySQL 底层执行原理:输入SQL语句到两阶段提交Mr. zhihao11 小时前
深入解析redis基本数据结构