为什么必须用'SET NAMES UTF8'

bycgeek 2013-02-08 10:10:56
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
??
...全文
499 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
LuciferStar 2013-02-13
  • 打赏
  • 举报
回复
数据库的默认字符集也要注意。
helloyou0 2013-02-12
  • 打赏
  • 举报
回复
character_set_client character_set_connection character_set_results 这几个是基于连接的, 就是说对同一个数据库的不同的连接可以有不同的设置. 你可以看见mysql_client_encoding有一个可选参数就是连接资源. 所以, mysql客户端的, 和你php程序的, 可以不同, 所以如果缺省的不是你需要的, 那么就要在连接数据库后, set names
bycgeek 2013-02-08
  • 打赏
  • 举报
回复
引用 2 楼 jordan102 的回复:
mysql_query("set names utf8");
问题是解决了,可是我不明白为什么PHP中现实的client字符集与我在服务器上设置的默认client字符集不一致?
一起混吧 2013-02-08
  • 打赏
  • 举报
回复
mysql_query("set names utf8");
bycgeek 2013-02-08
  • 打赏
  • 举报
回复
怎么没人回答啊 自己顶
bycgeek 2013-02-08
  • 打赏
  • 举报
回复
引用 5 楼 jordan102 的回复:
mysql_client_encoding 取的是客户端的字符集,而你上面列出来的是服务端的字符集。这两个是不同的。
这个难道也是服务器端字符集?
| character_set_client     | utf8                       |
xuzuning 2013-02-08
  • 打赏
  • 举报
回复
取决于mysql安装时的字符集选择 可以这样修改 mysqld --default-character-set=utf8
一起混吧 2013-02-08
  • 打赏
  • 举报
回复
mysql_client_encoding 取的是客户端的字符集,而你上面列出来的是服务端的字符集。这两个是不同的。
pg830616 2013-02-08
  • 打赏
  • 举报
回复
要看你客户端编写的时候用的字符集编码 如果你确定是UTF8那估计也不需要运行那个语句 mysql_query("set names utf8"); 这条语句的功能大概就是临时改变以下要执行的SQL的字符集,应该是大于全局的

21,886

社区成员

发帖
与我相关
我的任务
社区描述
从PHP安装配置,PHP入门,PHP基础到PHP应用
社区管理员
  • 基础编程社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧