Navicat「编辑数据库」仅影响新建表,默认不修改已有表的字符集和校对规则;结构同步须手动勾选Compare collation,否则忽略校对差异;直接执行ALTER TABLE CONVERT TO更安全可控。
右键数据库 →「编辑数据库」→ 修改 character set 和 collation,这个操作仅影响后续新建的表。已有表的 default charset、字段的 character set 全部保持原样。很多用户改完就去插 emoji,立刻报错 incorrect string value,就是因为误以为“库改了,表就跟着动了”。
这是最常被跳过的开关:Navicat 默认不比对校对规则,即使源表是 utf8mb4_0900_as_cs、目标是 utf8mb4_general_ci,差异列表里也不会标蓝,更不会生成 ALTER TABLE ... CONVERT TO 语句。
Compare collation
Compare auto-increment value,否则可能意外重置主键起始值name VARCHAR(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;如果只靠表级默认值,Navicat 可能判定“无差异”Collation 的条目,逐个确认是否勾选——允许单条取消,避免全量覆盖比起导出 SQL 文件再导入,直接在 Navicat 查询编辑器中粘贴并分批执行 ALTER TABLE ... CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci 更安全。文件编码、BOM、混入 CREATE DATABASE 或未设 DELIMITER 都可能让脚本执行失败。
ALTER DATABASE your_db_name CHARACTER SET = utf8mb4 COLLATE = utf8mb4_unicode_ci 设新表默认值SELECT CONCAT('ALTER TABLE `', table_schema, '`.`', table_name, '` CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;') FROM information_schema.tables WHERE table_schema = 'your_db_name';
COMMIT 一次` 反引号不能漏,否则语法错误比如源用 utf8mb4_0900_as_cs,但目标是 MySQL 5.7 或 MariaDB 10.3,它们不支持该校对规则。Navicat 在结构同步时可能不提示、不标红,直接跳过这条差异;而执行 CONVERT TO 时则会明确报错 Unknown collation。
SHOW COLLATION LIKE 'utf8mb4%';
utf8mb4_unicode_ci 或 utf8mb4_general_ci
utf8mb4_*
CONVERT TO 是否实际执行、每条字段的 CHARACTER SET 是否被重写——这些细节在结构同步预览里容易被忽略,必须人工核对。