郑州网站关键词优化,软装设计收费标准,python基础教程完整,荷城网站制作引言作为资深的DBA程序员#xff0c;在工作中是否会遇到更这样的情况呢#xff1f;原有数据库的字符集由于前期规划不足#xff0c;随着业务的发展不能满足业务的需求。如原来业务系统用的是utf8字符集#xff0c;后期有存储表情符号的需求#xff0c;uft8字符集就不能满足…引言作为资深的DBA程序员在工作中是否会遇到更这样的情况呢原有数据库的字符集由于前期规划不足随着业务的发展不能满足业务的需求。如原来业务系统用的是utf8字符集后期有存储表情符号的需求uft8字符集就不能满足此时的业务需求了。需要用utf8mb4字符集。数据库迁移源和目标数据库的字符集不一致需要在迁移之前进行转换。更换数据库字符集的时候明明很认(jian)真(dan),总是会出现各种各样的问题导致更换之后数据库的数据出现乱码今天小编就同大家一起梳理下如何正确更换数据库的字符集下文将简单讲解数据库不同字符集的转换过程。步骤转化杜绝乱码 常用字符集GBK是国家标准GB2312基础上扩容后兼容GB2312的标准。GBK的文字编码是用双字节来表示的即不论中、英文字符均使用双字节来表示为了区分中文将其最高位都设定成1。GBK包含全部中文字符是国家编码通用性比UTF8差不过UTF8占用的数据库比GBK大。支持简体中文及繁体中文。utf8字符集是一种UTF-8编码的Unicode字符集每个字符占用1到3个字节。UTF-8包含全世界所有国家需要用到的字符是国际编码通用性强。utf8mb4字符集是一种UTF-8编码的Unicode字符集每个字符占用1到4个字节。可以覆盖BMP范围内的字符和增补字符。BMP范围内的字符编码和utf8字符集中的编码是完全相同的长度也是完全一样的所以utf8mb4字符集可以兼容utf8字符集。GB2312是GBK的子集GBK是GB18030的子集。big5支持繁体中文转化过程以下模拟的是将latin1字符集的数据库修改成GBK的过程 。其他字符集的转换过程类似。需要注意的是要转换的目标字符集一定是源字符集的超级或者目标字符集的范围包含源字符集的范围。2.1 导表结构mysqldump -uroot -p --default-character-setgbk -d databasename createtb.sql其中--default-character-setgbk表示设置以什么字符集连接-d表示只导出表结构不导出数据。2.2 手工修改createtb.sql中表结构定义中的字符集为新的字符集。2.3 确保记录不再更新导出所有记录mysqldump -root -p --quick --no-create-info --extended-insert --default-character-setlatin1 databasenamedata.sql--quick该选项用于转储大的表。它强制mysqldump从服务器一次一行地检索表中的行而不是所有的行并在输出前将它缓冲到内存中。--extended-insert使用包括几个values列表的多行insert语法。这样使转储文件更小重载文件时可以加速插入。--no-create-info不导出每个转储表的create table语句。--default-character-setlatin1:按照原有的字符集导出所有数据。这样导出的文件中所有中文都是可见的不会保存成乱码。2.4 打开data.sql将set names latin1修改成set names bgk.2.5 使用新的字符集创建新的数据库。create database databasename default charset bgk;2.6 创建表,执行createtab.sqlmysql -root -p databasename 2.7 导入数据执行data.sqlmysql -root -p databasename 总结新的字符集一定要是原字符集的超集不然转化之后数据会出现乱码。常见字符集转换如下