php+mysql中文无法检索出数据

将数据库字符集设置为latin,并将字符转码成gb2312

将字符长度打印出来发现:因为latin中一个字符占用2个字节,utf-8中一个字符占用3个字节,这样一来检索的时候就会出现错误
实验过程:
$sql = "select LENGTH(\"".$account."\") as Level from playerproperty_".$table_num." a limit 1;";

在php中使用这段代码,得到的结果是每个中文3字节,因为php中使用的是utf-8,而粘贴到mysql中发现只使用了2字节,查看mysql字符集

所以设置如下

mysqli_set_charset($this->conn,"latin1");
mysqli_query($this->conn,"SET NAMES LATIN1;");

而在查询的时候加入转码

$account = iconv("utf-8", "gb2312", $user_account);

这样就好了

posted @ 2016-04-27 22:22  巫谢  阅读(267)  评论(0编辑  收藏  举报