查字符集用 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文章。
相关推荐
cui_ruicheng5 小时前
MySQL(四):数据类型与字段设计Full Stack Developme6 小时前
JVM 与 Linux 交互的核心原理皮皮学姐分享-ppx6 小时前
政府绿色采购数据库(2015-2024.3)珺毅同学6 小时前
YOLO生成预测json标签迁移问题骑士雄师6 小时前
18.4 长期记忆可修改版cfm_29146 小时前
JVM GC垃圾回收初步了解~小先生~6 小时前
Python从入门到放弃(一)天佑木枫7 小时前
第2天:变量与数据类型 —— 让程序记住信息闪电悠米7 小时前
黑马点评-Redis 消息队列-03_stream_consumer_groupDust-Chasing8 小时前
Claude Code源码剖析 - Claude Code 上下文压缩机制