深入Mysql字符集设置 图文版

所属分类: 数据库 / Mysql 阅读数: 682
收藏 0 赞 0 分享

mysql客户端与mysql服务端之间,存在着一个字符集转换器。

character_set_client          =>gbk:转换器就知道客户端发送过来的是gbk格式的编码

character_set_connection=>gbk:将客户端传送过来的数据转换成gbk格式

character_set_results        =>gbk:

注:以上三个字符集可以使用set names gbk来统一进行设置

例子:

create table test(

name varchar(64) NOT NULL

)charset utf8;#这里的utf8表示服务器端的字符编码

 

首先,往数据表test中插入一条数据

inert into test values('测试');

则,数据“测试”在数据库中是以“utf8”格式保存的

过程:

 

首先,通过mysql客户端,将数据发送给Mysql服务器,经过字符集转换器的时候,由于character_set_connection 值为gbk,所以会将客户端发送过来的数据转为gbk格式,紧接着,字符集转换器将数据要传送给服务器的时候,发现服务器是以utf8保存数据的,所以,在其内部会自动将数据由gbk转换成utf8格式

什么时候会出现乱码?

    客户端的数据格式与声明的 character_set_client不符

        通过 header('Content-type:text/html;charset=utf8');将客户端的数据转成utf8格式的,在数据经过“字符集转换器”的时候,由于character_set_client=gbk,而character_set_connection也等于gbk,所以从客户端传送过来的数据(其实是utf8格式)并不会被转换格式。

        但是,字符集转换器在讲数据发送给服务器的时候,发现服务器要的格式是utf8,所以会将当前数          据当做gbk格式来处理,从而转成utf8(但是,这一步其实已经错了。。。)。

    2.  result与客户端页面不符合的时候        

 将返回结果的格式设置为utf8,但是客户端接受的格式为gbk,因此会出现乱码

通过show character set 语法,可以显示所有可用的字符集

latin字符集

注意:Maxlen列显示用于存储一个字符的最大的字节数目。

utf8字符集

 

gbk字符集

什么时候会丢失数据?

对比以上三幅图可以知道,每种字符集中,用于存储一个字符的最大的字节数目都不同,utf8最大,latin最小。所以在经过字符集转换器的时候,如果处理不当,会造成数据丢失,而且是无法挽回的。

比如:

character_set_connection的值改为lantin的时候

从客户端发送过来的gbk数据,会被转成lantin1格式,因为gbk格式的数据占用的字符数较多,从而会造成数据丢失

总结:

character_set_client和character_set_results 一般情况下要一致,因为一个表示客户端发送的数据格式,另一个表示客户端接受的数据格式为了避免造成数据丢失,需让 character_set_connection的字符编码 大于 character_set_client的字符编码

更多精彩内容其他人还在看

mysql存储过程详解

我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储过程(Stored Procedure)是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中,用户通过指定存储过程的名字并给定参数(如果该存储过程带有参数)来调用执行它
收藏 0 赞 0 分享

Mysql 错误问题汇总(不断更新中)

Mysql 错误问题汇总,我们在开发过程中经常看到mysql的一些错误,这里整理下,方便需要的朋友
收藏 0 赞 0 分享

linux下mysql链接被防火墙阻止的解决方法

linux下安装了mysql,不能从其它机器访问 帐号已经授权从任意主机进行访问
收藏 0 赞 0 分享

Linux下mysql新建账号及权限设置方法

Linux下mysql新建账号及权限设置方法,其实linux与windows下的设置方法一样的,都是命令行操作
收藏 0 赞 0 分享

详解MySQL存储过程参数有三种类型(in、out、inout)

MySQL 存储过程参数有三种类型:in、out、inout。它们各有什么作用和特点呢
收藏 0 赞 0 分享

mysql 常用设置 字符集编码、自动完成(自动提示)、监听外网ip

mysql 常用设置 字符集编码、自动完成(自动提示)、监听外网ip,需要的朋友可以参考下
收藏 0 赞 0 分享

远程连接mysql数据库注意事项记录(远程连接慢skip-name-resolve)

有时候我们需要远程连接mysql数据库,就需要注意下面的问题,方便大家解决,脚本之家小编特为大家准备了一些资料
收藏 0 赞 0 分享

深入Mysql字符集设置[精华结合]

深入Mysql字符集设置,建议大家看本文之前先看风雪之隅的文章,需要的朋友可以参考下
收藏 0 赞 0 分享

mysql字符集和校对规则(Mysql校对集)

字符集的概念大家都清楚,校对规则很多人不了解,一般数据库开发中也用不到这个概念,mysql在这方便貌似很先进,大概介绍一下
收藏 0 赞 0 分享

安装MySQL 5后无法启动(不能Start service)解决方法小结

有时候我们在安装mysql软件时,却无法启动,或服务器安全设置以后都可能导致mysql无法运行
收藏 0 赞 0 分享
查看更多