根本原因是客户端、服务端、连接层三者字符集不一致,SET NAMES utf8mb4仅临时修改当前会话连接层设置;需统一配置my.cnf/my.ini中client、mysql、mysqld段的字符集,并在建库建表时显式指定utf8mb4,同时确保客户端驱动支持并正确初始化。MySQL 客户端连接时显示乱码,SET NAMES utf8mb4 临时有效但重启就失效根本原因是客户端、服务端、连接层三者字符集不一致,而 SET NAMES utf8mb4 只改当前会话的连接层设置,不影响后续新连接。真正要管住所有连接,得从配置源头下手。修改 my.cnf(Linux)或 my.ini(Windows),在 client、mysql、mysqld 三个段落下分别加 default-character-set = utf8mb4(旧版本)或 character-set-client-handshake = FALSE + collation-server = utf8mb4_unicode_ci(推荐)mysqld 段必须设 character-set-server = utf8mb4,否则新建库默认还是 latin1注意:MySQL 8.0+ 已弃用 default-character-set,只认 character-set-server 和 collation-server;如果配置了已废弃项,启动时会报 warning 但不会失败,容易误以为生效了建库/建表时没指定字符集,导致插入中文报错 Incorrect string value这是典型的 utf8mb4 未穿透到表结构层------即使服务端全局设对了,建库建表不显式声明,依然可能沿用老默认值。创建数据库时务必写全:CREATE DATABASE db_name CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;已有库可修改:ALTER DATABASE db_name CHARACTER SET = utf8mb4 COLLATE = utf8mb4_unicode_ci;建表时别省略:CREATE TABLE t (c VARCHAR(10)) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;特别注意:MySQL 的 utf8 实际是阉割版(最多 3 字节),不支持 emoji 和部分生僻汉字;必须用 utf8mb4,且客户端驱动也要支持(如 JDBC 需加 ?characterEncoding=utf8mb4)PHP/Python 连接 MySQL 后仍乱码,mysqli_set_charset() 或 conn.set_character_set('utf8mb4') 不起作用代码层设置晚于连接建立,如果连接握手时服务端按旧配置发了 latin1,再调函数也救不回来。 Ideogram Ideogram是一个全新的文本转图像AI绘画生成平台,擅长于生成带有文本的图像,如LOGO上的字母、数字等。
相关推荐
Dxy12393102162 分钟前
Django 数据库 ENGINE 完全指南:选错了,性能差 10 倍小马爱打代码9 分钟前
Redis 和 MySQL 双写一致性:延迟双删、读写锁、MQ、Canal 怎么选?码不停蹄的玄黓14 分钟前
Java 生产者-消费者模型详解数智顾问25 分钟前
(133页PPT)数据中心基础设施规划设计(附下载方式)l1t29 分钟前
DeepSeek总结的PostgreSQL 的开源 TDE:pg_tde南极企鹅29 分钟前
深入理解 MVCC:数据库并发控制的基石欧神附体12330 分钟前
MYSQL数据库集群高可用和数据监控平台项目abcy07121344 分钟前
python在models定义了一个对象,接口调用时报错对象不存在models.xx.DoesNotExist無限進步D1 小时前
MySQL 数据处理之增删改