如何使用命令批量转换 utf8 到utf8mb4 编码

发布于 2020-07-04 09:42:23

如图:
image.png

查看更多

关注者
0
被浏览
43
1 个回答
张一冰
张一冰 2020-07-04
291,129,25

1. 首先修改数据库:

将数据库和已经建好的表也转换成utf8mb4

更改数据库编码(字符集):

ALTER DATABASE DATABASE_NAME(数据库名)  DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;

更改表编码(字符集)(注意:这里修改的是表的字符集,表里面字段的字符集并没有被修改):

ALTER TABLE TABLE_NAME(表名) DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci; 

如果全部表或者某些表都需要修改,需要通过允许下面的语句生成命令,然后运行

SELECT CONCAT('ALTER TABLE ',TABLE_NAME,' DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;') from information_schema.`TABLES` WHERE TABLE_SCHEMA = DATABASE_NAME(数据库名) and TABLE_NAME like '%TABLE_NAME(表名)%';

更改表编码(字符集)和表中所有字段的编码(字符集):

ALTER TABLE TABLE_NAME(表名) CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;

同理,如果需要批量,也可以使用上面的语句

撰写答案

请登录后再发布答案,点击登录

发布
问题

分享
好友

手机
浏览

扫码手机浏览