如下面两张图,全部将character_set_client , character_set_connection 和 character_set_results 设为 gbk 或 utf8 均是乱码,这到底是怎么回事啊?
原因就那么几个:
1你建立数据库时字体没有设定为utf8,系统默认其他,然后你改用utf8,数据库中内容没转码,然后取出来也就是乱码
2传进去的字符一开始就不是utf8,,,
3不知你用的什么是cmd还是shell,它用的编码和你数据库中保存的不一样
1、检查并修改mysql的my.ini的配置文件:
default-character-set=utf8
2、建立数据库要指定字符集:
create database mydb default character set utf8 collate utf8_general_ci;
3、建立表也要指定字符集:
CREATE TABLE IF NOT EXISTS `mydb` (
`username` varchar(64) NOT NULL,
`userid` int(11) NOT NULL,
) ENGINE=InnoDB DEFAULT CHARSET=utf8;