如何正确更换MySQL数据库字符集

发布时间:2021-11-29 15:43:14 作者:柒染
来源:亿速云 阅读:253

这篇文章将为大家详细讲解有关如何正确更换MySQL数据库字符集,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

作为资深的DBA程序员,在工作中是否会遇到更这样的情况呢?

原有数据库的字符集由于前期规划不足,随着业务的发展不能满足业务的需求。如原来业务系统用的是utf8字符集,后期有存储表情符号的需求,uft8字符集就不能满足此时的业务需求了。需要用utf8mb4字符集。

数据库迁移,源和目标数据库的字符集不一致,需要在迁移之前进行转换。

更换数据库字符集的时候明明很认(jian)真(dan),总是会出现各种各样的问题,导致更换之后数据库的数据出现乱码!

如何正确更换MySQL数据库字符集

今天小编就同大家一起梳理下如何正确更换数据库的字符集,下文将简单讲解数据库不同字符集的转换过程。步骤转化,杜绝乱码!

常用字符集

如何正确更换MySQL数据库字符集

转化过程

以下模拟的是将latin1字符集的数据库修改成GBK的过程  。其他字符集的转换过程类似。需要注意的是要转换的目标字符集一定是源字符集的超级或者目标字符集的范围包含源字符集的范围。

如何正确更换MySQL数据库字符集

1. 导表结构

mysqldump -uroot -p --default-character-set=gbk -d databasename >createtb.sql

其中--default-character-set=gbk表示设置以什么字符集连接,-d表示只导出表结构,不导出数据。

2. 手工修改createtb.sql中表结构定义中的字符集为新的字符集。

3. 确保记录不再更新,导出所有记录

mysqldump -root -p --quick --no-create-info --extended-insert --default-character-set=latin1 databasename>data.sql

4. 打开data.sql,将set names latin1修改成set names bgk.

5. 使用新的字符集创建新的数据库。

create database databasename default charset bgk;

6. 创建表,执行createtab.sql

mysql -root -p databasename <createtb.sql

7. 导入数据,执行data.sql

mysql -root -p databasename <data.sql

总结

新的字符集一定要是原字符集的超集,不然转化之后,数据会出现乱码。常见字符集转换如下:

如何正确更换MySQL数据库字符集

关于如何正确更换MySQL数据库字符集就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

推荐阅读:
  1. 记一次证书更换姿势不正确导致的曲折经历
  2. 如何更改生产MySQL数据库库表的字符集

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

mysql 数据库

上一篇:C++内联函数有什么作用

下一篇:C/C++ Qt TreeWidget单层树形组件怎么应用

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》