客户端和服务端之间有一个连接器,客户端和服务端的字符集可以不相同,只要在取数据的时候告诉服务器想要什么字符集的结果就行。
所以,出现获取到的数据出现乱码,是因为获取到的数据的编码方式不是客户端所能接受的。
查看字符集:
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;
**校对集:**就是字符串的排序规则