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

相关推荐
pixcarp7 小时前
知识库系统的内容资产闭环怎么设计
服务器·数据库·后端·golang
JosieBook7 小时前
【数据库】时序预测能力的分级进化:TimechoAI如何让每一类用户都能精准预见未来
java·开发语言·数据库
吴声子夜歌9 小时前
SQL经典实例——使用多张表
数据库·sql
倔强的石头_10 小时前
《Kingbase护城河》——深度解密数据库行锁冲突与等待事件架构
数据库
IT策士10 小时前
Redis 从入门到精通:性能调优与多语言客户端对比
数据库·redis·缓存
Bert.Cai11 小时前
Oracle INSTR函数详解
数据库·oracle
茉莉玫瑰花茶13 小时前
综合案例 - AI 智能租房助手 [ 5 ]
服务器·数据库·人工智能·python·ai
ywl47081208713 小时前
jwt生产token,简单版helloworld
java·数据库·spring
器灵科技13 小时前
AI视频工具实测:Seedance/可灵/HappyHorse谁最能打?
java·运维·数据库·人工智能·github
huangdong_13 小时前
京东商品图片视频批量下载与m3u8视频合并技术完整实现方案
大数据·前端·数据库