MySQL+PHP出现乱码 在用mysql客户端时显示字符集如下:
+--------------------------+----------------------------+
| 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       | /usr/share/mysql/charsets/ |
+--------------------------+----------------------------+PHP中:echo mysql_client_encoding();
显示的是:latin1
??phpmysql乱码

解决方案 »

  1.   

    mysql_query("set names utf8");
      

  2.   

    问题是解决了,可是我不明白为什么PHP中现实的client字符集与我在服务器上设置的默认client字符集不一致?
      

  3.   

    要看你客户端编写的时候用的字符集编码
    如果你确定是UTF8那估计也不需要运行那个语句
    mysql_query("set names utf8");
    这条语句的功能大概就是临时改变以下要执行的SQL的字符集,应该是大于全局的
      

  4.   

    mysql_client_encoding 取的是客户端的字符集,而你上面列出来的是服务端的字符集。这两个是不同的。
      

  5.   

    取决于mysql安装时的字符集选择可以这样修改
    mysqld --default-character-set=utf8
      

  6.   

    这个难道也是服务器端字符集?
    | character_set_client     | utf8                       |
      

  7.   

    character_set_client     
    character_set_connection 
    character_set_results    
    这几个是基于连接的, 就是说对同一个数据库的不同的连接可以有不同的设置. 你可以看见mysql_client_encoding有一个可选参数就是连接资源. 所以, mysql客户端的, 和你php程序的, 可以不同, 所以如果缺省的不是你需要的, 那么就要在连接数据库后, set names