设为首页 收藏本站
查看: 733|回复: 0

[经验分享] MySQL--字符编码和字符集

[复制链接]
YunVN网友  发表于 2018-10-7 08:28:11 |阅读模式
前言:
  一般来说,出现中文乱码,都是客户端和服务端字符集不匹配导致的原因。(默认未指定字符集创建的数据库表,都是latinl字符集, 强烈建议使用utf8字符集)
  保证不出现乱码的思想:保证客户端、服务端、数据库、表字符集统一
  坑:有的时候,cmd或者linux系统字符集问题,其实数据库是正确的,只是我们执行命令在终端看到的是乱码而已,这时需要设置linux系统字符集
  1、查看liunx系统字符集:cat /etc/sysconfig/i18n
  2、vim /etc/sysconfig/i18n

  备注:始终牢记,存放数据的是字段,所以编码最后是以字段的编码为准,数据库和表的编码影响的时候字段的默认值,也就是说在设置了数据库编码之后,新建的表在不指定的情况下就会和数据库编码相同,而不指定字段的编码时,字段的编码和表相同。如果使用>
一、查看是什么字符集

1、查寻数据库是什么字符集
  

show create database django\G (django 是数据库名称)  

DSC0000.jpg


2、查寻表是什么字符集
  

show create table auth_group\G (auth_group 是表名称)  

DSC0001.jpg

  

ENGINE = InnoDB 该表数据库引擎是InnoDB  
DEFULT CHARSET=utf8 该表字符集是utf8
  
COLLATE utf8_general_ci 校准规则
  


3、查看所有字符集和对应的校准规则
  

show character set;  

DSC0002.jpg


二、解决方法:

1、插入数据的时候,先设置客户端插入字符集和数据库建表相同的字符集
  

eg:如果数据库表字符集是latinl,那么插入数据的时候也要是latinl  
方法:set names latinl
  
insert into student value('飞东')
  

DSC0003.jpg

DSC0004.jpg


2、将SQL语句放入文件中,使用source来执行这个文件,插入数据,则不会出现乱码,原理是和1一样的,只是放在文件中执行而已
  方法:将下面两个语句放入一个新建文件中,如mysql.sql
  

set names Latinl  
insert into student value('飞东')
  
执行这个文件:source mysql.sql
  

DSC0005.jpg


3、从其他文件导入数据库(避免导入数据有中文乱码的问题)
  将数据编码格式保存为utf-8(UTF8不要导入gbk,gbk不要导入UTF8)
  

set names utf8;  
ALTERDATABASEDEFAULTCHARACTERSETCOLLATE utf8_general_ci;  修改数据库的编码格式
  
ALTERTABLEDEFAULTCHARACTERSETCOLLATE utf8_general_ci;     修改表的编码格式
  
LOADLOCAL'C:\\utf8.txt'INTOTABLE tb_name;    从文件中导入数据库
  


4、永久修改默认客户端编码格式(修改my.cnf配置文件,针对MySQL 5.5版本以上)
DSC0006.jpg

DSC0007.jpg


5、永久修改默认服务端编码格式(修改my.cnf配置文件,针对MySQL 5.5版本以上)
DSC0008.jpg

DSC0009.jpg

  修改完毕之后重启mysqld服务:service mysqld restart

三、常用命令

1、查看默认编码格式 show variables like "%char%";
DSC00010.jpg

DSC00011.jpg

DSC00012.jpg

  

character_set_client(客户端)、character_set_connection(连接)、character_set_results(结果) 三者字符集是一致的  


2、修改数据库的编码格式
  

ALTERDATABASEDEFAULTCHARACTERSETCOLLATE utf8_general_ci;    


3、修改表的编码格式
  

ALTERTABLEDEFAULTCHARACTERSETCOLLATE utf8_general_ci;    


4、通过ALTER 修改库或者表的字符集,只是对之后插入的数据有效,原来已经存在的数据无法修改,如果需要修改原来带有数据的字符集,只能通过把原来的数据导出来,再插入到新的已经修改过字符集的表(数据库)中。

四、建议

1、中英文环境,linux设置系统字符集为utf8,数据库服务端,客户端,数据库,表都是utf8字符集

2、无论是查寻还是插入,都先用set names utf8 先设置一下字符集

3、建议建数据库语句:
DSC00013.jpg


4、建议表语句:
DSC00014.jpg

  4、建议表语句:



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-614146-1-1.html 上篇帖子: mysql主从复制笔记 下篇帖子: 常见的高可用MySQL解决方案转载
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表