MySQL解决客户端获取的数据乱码

客户端和服务端之间有一个连接器,客户端和服务端的字符集可以不相同,只要在取数据的时候告诉服务器想要什么字符集的结果就行。

所以,出现获取到的数据出现乱码,是因为获取到的数据的编码方式不是客户端所能接受的。

查看字符集:

show variables like '%character%';

+--------------------------+------------------------------------+
| Variable_name            | Value                              |
+--------------------------+------------------------------------+
| character_set_client     | utf8                               |
| character_set_connection | utf8                               |
| character_set_database   | utf8                               |
| character_set_filesystem | binary                             |
| character_set_results    | utf8                               |
| character_set_server     | utf8                               |
| character_set_system     | utf8                               |
| character_sets_dir       | D:\webserver\mysql\share\charsets\ |
+--------------------------+------------------------------------+

character_set_client:客户端使用的编码,如果是gbk就设为gbk

character_set_results:服务器范围的数据集的编码,客户端可以接收的编码

所以只要把这两个的值设置成客户端的编码,就不会出现乱码啦。

客户端连接之后设置:

set names utf8;   // 表示character_set_client、character_set_connection、character_set_results都设置成utf8

也可以建表的时候指定编码:

create table test (
 ....
) engine=innodb default charset=utf8;

**校对集:**就是字符串的排序规则

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值