将数据库字符集设置为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);
这样就好了