查字符集用 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文章。
相关推荐
Bert.Cai1 小时前
MySQL CEIL()函数详解m0_602857761 小时前
Chart.js 4 中实现基于数据极值的垂直线性渐变填充夏恪1 小时前
如何计算SQL同比环比数据_利用窗口函数LAG与LEAD念恒123061 小时前
Python(运算与操作)TDengine (老段)1 小时前
工业软件的未来:构建在工业数据底座之上的 AI Agentqq_349317481 小时前
Tailwind CSS如何自定义间距数值_配置theme spacing扩展CSS边距coderlin_1 小时前
Langgraph项目三 agent搭建xyx-3v1 小时前
信号量(二进制/计数)u0110225122 小时前
HTML5多媒体资源动态替换Source标签的刷新机制