Mysql 表字符集变更

背景

线上有几张表的字符集是 latin1,要求换成utf8mb4。至于操作的时机则需要自行判断。

1.查看库中所有字符集为latin1的所有表

sql 复制代码
SELECT
	DISTINCT
	table_schema,
	table_name,
	collation_name,
	character_set_name,
	CONCAT('ALTER TABLE ', table_schema, '.', table_name, ' CONVERT TO CHARACTER SET \'utf8mb4\' COLLATE \'utf8mb4_general_ci\';') '修正SQL'
FROM
	information_schema.COLUMNS 
WHERE
	COLLATION_NAME IS NOT NULL 
	AND COLLATION_NAME LIKE 'latin1%';

2.备份所有相关表

进入 mysql 安装目录下的 bin 目录使用 mysqldump 命令进行表备份。

2.1 备份表结构和数据(用作恢复):

示例:mysqldump -uroot -p [库名] [表名] > 某个表的结构和数据备份文件.sql

回车后输入密码执行备份。

2.2 仅备份数据(用于修改字符集后导入数据):

示例:mysqldump -t -uroot -p [库名] [表名] > 某个表的数据备份文件.sql

回车后输入密码执行备份。

3.问题表依次执行

3.1 查看原有索引并记录成创建SQL

示例:SHOW INDEX FROM [库名].[表名];

3.2 清空表

示例:TRUNCATE TABLE [库名].[表名];

3.3 删除索引

示例:ALTER TABLE [库名].[表名] DROP INDEX [索引名称];

3.4 修改字符集

示例:ALTER TABLE [库名].[表名] CONVERT TO CHARACTER SET 'utf8mb4' COLLATE 'utf8mb4_general_ci';

3.5 创建索引

示例:CREATE INDEX [索引名称] ON [库名].[表名]([字段名...]);

3.6 导入数据

进入 mysql 安装目录下的 bin 目录使用 mysql 命令进行数据导入。

示例:mysql -uroot -p [库名] < 某个表的数据备份文件.sql

相关推荐
XDHCOM1 分钟前
ORA-32152报错咋整啊,数据库操作遇到null number问题远程帮忙修复
服务器·数据库·oracle
专利观察员12 分钟前
输配电行业创新转型实践:南宁迪**力有限公司的专利策略调整、专利检索工具采用
数据库·科技·专利·专利申请
jgyzl16 分钟前
2026.3.9 Redis内存回收内存淘汰
数据库·redis·缓存
白露与泡影25 分钟前
MySQL 时间类型选型避坑:timestamp 和 datetime 该怎么选?
数据库·mysql
青槿吖2 小时前
第二篇:告别XML臃肿配置!Spring注解式IOC/DI保姆级教程,从入门到真香
xml·java·开发语言·数据库·后端·sql·spring
运维 小白2 小时前
2. 部署mysql服务并监控mysql
数据库·mysql·adb
聪明人3 小时前
macOS安装Redis
数据库·redis·macos
北漂Zachary3 小时前
Mysql中使用sql语句生成雪花算法Id
sql·mysql·算法
weixin_505154463 小时前
Bowell Studio:重塑工业互联网时代的装配制造与运维检修
运维·数据库·人工智能·制造·数字孪生·3d产品配置器·3d交互展示
sa100273 小时前
淘宝商品详情 API 接口开发实战:item_detail 调用、参数与 Python 示例
linux·数据库·python