PHP+MYSQL中文乱码问题


Posted in PHP onJuly 01, 2015

从MySQL 4.1开始引入多语言的支持,但是用PHP插入的中文会出现乱码.无论用什么编码也不行.

解决这个问题其实很简单.

1.在建表的时候设置编码类型为gb2312_chinese_ci.

2.在PHP页面的数据库连接语句加一行mysql_query("SET NAMES 'gb2312'",$link); 例如

$db_host="localhost"; 
$db_user="root"; 
$db_password="password"; 
$db_name="test";

$link=mysql_connect($db_host,$db_user,$db_password);
mysql_query("SET NAMES 'gb2312'",$link); 
$db=mysql_select_db($db_name,$link); 
$query="select * from user"; 
$result=mysql_query($query);

写入页面和读取页面都加入这行.这样在MYSQL里面的中文就能正常显示了.

相关资料:

从MySQL 4.1开始引入多语言的支持,而且一些特性已经超过了其他的数据库系统。
MySQL4.1的字符集支持(Character Set Support)有两个方面:字符集(Characterset)和排序方式(Collation)。对于字符集的支持细化到四个层次:服务器 (server),数据库(database),数据表(table)和连接(connection)。
查看系统的字符集和排序方式的设定可以通过下面的两条命令:!

mysql> show variables like 'character_set_%';
+--------------------------+----------------------------+
| Variable_name | Value |
+--------------------------+----------------------------+
| character_set_client | latin1 |
| character_set_connection | latin1 |
| character_set_database | latin1 |
| character_set_results | latin1 |
| character_set_server | latin1 |
| character_set_system | utf8 |
| character_sets_dir | /usr/share/mysql/charsets/ |
+--------------------------+----------------------------+
7 rows in set (0.00 sec)
mysql> show variables like 'collation_%';
+----------------------+-------------------+
| Variable_name | Value |
+----------------------+-------------------+
| collation_connection | latin1_swedish_ci |
| collation_database | latin1_swedish_ci |
| collation_server | latin1_swedish_ci |
+----------------------+-------------------+
3 rows in set (0.00 sec)

上面列出的值就是系统的默认值。(很奇怪系统怎么默认是latin1的瑞典语排序方式)...
当我们按照原来的方式通过PHP存取MySQL数据库时,就算设置了表的默认字符集为utf8并且通过UTF-8编码发送查询,你会发现存入数据库的仍然是乱码。问题就出在这个connection连接层上。解决方法是在发送查询前执行一下下面这句:
set names 'utf8';
它相当于下面的四句指令:

set character_set_client = utf8;

set character_set_results = utf8;

set character_set_connection = utf8;

set collation_connection = utf8_general_ci

由于默认网页提交的查询是gb2312(表单页面meta里可以看到),而mysql默认将其当作utf8(可以查到此时的 character_set_client=utf8),所以必然乱码。同理,mysql返回的结果是已经转换成 character_set_results编码的(与表的编码无关),同样默认是utf8,而网页页面把它当gb2312处理,所以必然有标题等由数据 库读出的字段是乱码而其他php部分文字不乱码的现象。

解决(by 一剑飘雪):
安装mysql5.0时要选utf8字符集(在用phpmyadmin创建数据库和字段时就不需要在整理中选utf8字符集了),并在php建立连接后发送

$link = mysql_connect('localhost', 'root', 'root');

mysql_query("SET NAMES 'utf8'",$link);

这时我们在网页中看到的还是乱码但已不是????了,查看网页源文件,已完全正常。用记事本打开php源文件,别存为utf8编码,再刷新网页,全部搞定了。
或者,当然还是要安装时仍要utf8安装,在php中发送set names 'gb2312',同时php文件存为记事本默认的ansi,也能正确显示中文.

但总不能每次连接时都发送一次SET NAMES 'utf8'吧,如何彻底解决还没找到方法。

这样安装mysql时缺省字符集选为utf8后又带来一个问题,我们在command.exe中进入mysql控制台后,查询结果又成了乱码,我们可以在查询前输入

mysql>set names 'gbk';

mysql>set names 'gb2312';

相当于告诉mysql客户端在使用gb2312字符集,结果就正确了,gb2312为GBK的子集.

PHP 相关文章推荐
利用文件属性结合Session实现在线人数统计
Oct 09 PHP
php 文件状态缓存带来的问题
Dec 14 PHP
php学习笔记 面向对象的构造与析构方法
Jun 13 PHP
PHP中strtotime函数使用方法详解
Nov 27 PHP
PHP register_shutdown_function函数的深入解析
Jun 03 PHP
使用GDB调试PHP代码,解决PHP代码死循环问题
Mar 02 PHP
FastCGI 进程意外退出造成500错误
Jul 26 PHP
在Win2003(64位)中配置IIS6+PHP5.2.17+MySQL5.5的运行环境
Apr 04 PHP
PHP中empty,isset,is_null用法和区别
Feb 19 PHP
PHP实现十进制、二进制、八进制和十六进制转换相关函数用法分析
Apr 25 PHP
基于CI(CodeIgniter)框架实现购物车功能的方法
Apr 09 PHP
php引用和拷贝的区别知识点总结
Sep 23 PHP
PHP+shell实现多线程的方法
Jul 01 #PHP
WordPress中"无法将上传的文件移动至"错误的解决方法
Jul 01 #PHP
wamp服务器访问php非常缓慢的解决过程
Jul 01 #PHP
nginx+thinkphp下解决不支持pathinfo模式
Jul 01 #PHP
Smarty foreach控制循环次数的一些方法
Jul 01 #PHP
在Linux系统下一键重新安装WordPress的脚本示例
Jun 30 #PHP
Yii扩展组件编写方法实例分析
Jun 29 #PHP
You might like
实例(Smarty+FCKeditor新闻系统)
2007/01/02 PHP
深入PHP curl参数的详解
2013/06/17 PHP
Symfony2 session用法实例分析
2016/02/04 PHP
php微信公众号开发(4)php实现自定义关键字回复
2016/12/15 PHP
PHP命名空间用法实例分析
2019/09/04 PHP
tp5.1 实现setInc字段自动加1
2019/10/18 PHP
jquery 指南/入门基础
2007/11/30 Javascript
js setattribute批量设置css样式
2009/11/26 Javascript
JavaScript Cookie显示用户上次访问的时间和次数
2009/12/08 Javascript
javascript与CSS复习(《精通javascript》)
2010/06/29 Javascript
JS 自定义带默认值的函数
2011/07/21 Javascript
js绑定事件this指向发生改变的问题解决方法
2013/04/23 Javascript
Jquery时间验证和转换工具小例子
2013/07/01 Javascript
js数组的基本用法及数组根据下标(数值或字符)移除元素
2013/10/20 Javascript
IE中的File域无法清空使用jQuery重设File域
2014/04/24 Javascript
js创建对象的区别示例介绍
2014/07/24 Javascript
javascript实现不同颜色Tab标签切换效果
2016/04/27 Javascript
Django1.7+JQuery+Ajax验证用户注册集成小例子
2017/04/08 jQuery
jsonp实现百度下拉框功能的方法分析
2019/05/10 Javascript
jQuery实现数字华容道小游戏(实例代码)
2020/01/16 jQuery
JS实现滑动拼图验证功能完整示例
2020/03/29 Javascript
详解vue中v-on事件监听指令的基本用法
2020/07/22 Javascript
Python中使用Boolean操作符做真值测试实例
2015/01/30 Python
浅谈pandas中shift和diff函数关系
2018/04/08 Python
PyQt5每天必学之弹出消息框
2018/04/19 Python
解决Python 中英文混输格式对齐的问题
2018/07/16 Python
Python使用循环神经网络解决文本分类问题的方法详解
2020/01/16 Python
Python super()方法原理详解
2020/03/31 Python
Python经纬度坐标转换为距离及角度的实现
2020/11/01 Python
python读取图片颜色值并生成excel像素画的方法实例
2021/02/19 Python
GAP欧盟网上商店:GAP EU
2016/09/13 全球购物
Liu Jo西班牙官网:意大利服装品牌
2019/09/11 全球购物
难忘的一天教学反思
2014/04/30 职场文书
小学生优秀作文范文(六篇)
2019/07/10 职场文书
《哪吒之魔童降世》观后感:世上哪有随随便便的成功
2019/11/08 职场文书
浅谈python中的多态
2021/06/15 Python