当前位置: 首页 > news >正文

Mysql 表字符集变更

背景

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

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

SELECTDISTINCTtable_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'
FROMinformation_schema.COLUMNS 
WHERECOLLATION_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

http://www.lryc.cn/news/146641.html

相关文章:

  • golang抓取tcp包的实现
  • oauth2.0第2季 分布式认证与授权实现单点登录
  • SpringBoot一些困惑及梳理
  • PostgreSQL汉字转拼音首字母
  • HBuilderX修改manifest.json设置,解决跨域问题(CORS、Cross-Origin)
  • AR地图微信小程序:数字化时代下地图应用的新突破
  • 成集云 | 抖店客户静默下单催付数据同步钉钉 | 解决方案
  • C++中的运算符总结(5):按位逻辑运算符
  • 《异常检测——从经典算法到深度学习》22 Kontrast: 通过自监督对比学习识别软件变更中的错误
  • 大数据风控介绍
  • Linux内核学习(九)—— 虚拟文件系统(基于Linux 2.6内核)
  • 【模拟】算法实战
  • 各个微服务模块之间互相依赖调用的问题
  • 理论转换实践之keepalived+nginx实现HA
  • 华为OD七日集训第1期复盘 - 按算法分类,由易到难,循序渐进,玩转OD(文末送书)
  • MPI之持久化通信句柄与非持久化通信句柄
  • 搭建个人备忘录中心服务memos、轻量级笔记服务
  • 探究代理技术在网络安全、爬虫与HTTP通信中的多重应用
  • vue左侧漏斗切换 echart图表动态更新
  • Centos7安装ZK-UI管理界面安装|Maven|Git|
  • C语言日常刷题7
  • 037 - 有关时间和日期的函数方法
  • (JAVA)树——tree
  • js判断对象是否为空对象的方法总结
  • LeetCode1049. 最后一块石头的重量 II
  • universal robot 机械臂 官方基本教程
  • 网络常见安全漏洞
  • 【JS案例】JS实现图片放大镜功能
  • linux centos7 bash中字符串反向输出
  • c++:QT day1 认识与学习