MYSQL中关于编码问题

我们需要使用mysql语句:show variables like 'char%';可查询到当前的内容

 character_set_client     | utf8 --> mysql把我们客户端传递的数据都当成是utf8 也是给它传递utf8,如果我们传递的是gbk,那么需要修改这个变量为gbk

 character_set_connection | utf8
 character_set_database   | utf8
 character_set_results    | utf8 --> mysql发送给客户端的数据都是utf8的。客户端用utf8编码,如果客户端使用gbk来编码,那么需要修改这个变量为gbk的。
 character_set_server     | utf8
 character_set_system     | utf8

character_set_client=utf8,无论客户端发送的是什么编码的数据,mysql都当成是utf8的数据!
  > 若客户端发送的是GBK
  > 服务器会当成utf8对待
  > 总结:必然乱码!


处理问题的手段有两种;
  > 让客户端发送utf8的数据(行不通)
  > 把character_set_client修改为gbk
  set character_set_client=gbk; --> 只在当前窗口内有效,也就是说,关闭窗口后,再打开,又回到utf8了。


character_set_results=utf8,把数据用什么编码发送给客户端!
  > 若服务器发送给客户端的是utf8的数据
  > 客户端会把它当成gbk,因为我们的小黑屏,只能显示gbk
  > 总结:必然乱码!


处理问题的手段有两种:
  > 让服务器发送gbk的数据:set character_set_results=gbk
  > 让小黑屏使用utf8来解读(行不通)


my.ini
  在总配置文件中进行配置,可以一劳永逸
在文件中更改之后以后可以不用管这个问题
[client]
port=3306

[mysql]
default-character-set=gbk /*它可以一劳永逸!它可以修改三个变量:client、results、connection*/
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值