最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
如何借助Navicat可视化界面批量修改表的字符集和校对规则?
时间:2026-06-20 09:41:46 编辑:袖梨 来源:一聚教程网
Navicat「编辑数据库」仅影响新建表,默认不修改已有表的字符集和校对规则;结构同步须手动勾选Compare collation,否则忽略校对差异;直接执行ALTER TABLE CONVERT TO更安全可控。
Navicat「编辑数据库」只改默认值,不改已有表
右键数据库 →「编辑数据库」→ 修改 character set 和 collation,这个操作仅影响后续新建的表。已有表的 default charset、字段的 character set 全部保持原样。很多用户改完就去插 emoji,立刻报错 incorrect string value,就是因为误以为“库改了,表就跟着动了”。
结构同步(Structure Synchronization)必须手动勾选 Compare collation
这是最常被跳过的开关:Navicat 默认不比对校对规则,即使源表是 utf8mb4_0900_as_cs、目标是 utf8mb4_general_ci,差异列表里也不会标蓝,更不会生成 ALTER TABLE ... CONVERT TO 语句。
- 进入结构同步向导 → 点击「Options」→ 勾选
Compare collation - 务必取消勾选
Compare auto-increment value,否则可能意外重置主键起始值 - 源表字段定义中要显式带字符集,比如
name VARCHAR(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;如果只靠表级默认值,Navicat 可能判定“无差异” - 比对完成后,在差异列表中筛选类型为
Collation的条目,逐个确认是否勾选——允许单条取消,避免全量覆盖
直接在查询窗口执行 CONVERT TO 最可控
比起导出 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'; - 复制结果 → 粘贴进查询窗口 → 关闭自动提交 → 每执行 5 张表就手动
COMMIT一次 - 表名含横线或数字开头时,
`反引号不能漏,否则语法错误
目标库不支持源 COLLATION 时会静默跳过或报错
比如源用 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 - 达梦 DM8 需确认已启用 UTF-8 模式,否则同样不认
utf8mb4_*
CONVERT TO 是否实际执行、每条字段的 CHARACTER SET 是否被重写——这些细节在结构同步预览里容易被忽略,必须人工核对。
相关文章
- 异环棋子有何作用 06-20
- 亿万光年联合要塞如何选 06-20
- 西普大陆优雅侍鸟怎么获取 06-20
- 智能体平台开发者API接入:密钥获取与权限配置说明 06-20
- 伊莫超可狼人是哪些 06-20
- 蛋仔派对出号哪里选 06-20