写数据库插入的时候输入中文,在数据库中显示为乱码或空?

为什么呢?

因为字符编码的不统一。

解决方法:

首先确定你各部分的编码。

mysql编码查询:

在你的mysql的安装目录下有个bin文件夹,点开里面的mysql.exe 就进入了控制台。

输入控制台代码    show variables like ‘%character_set_%’;  回车,

就会显示如图

从上图中可以看到 MySQL 有六处使用了字符集,分别为:client 、connection、database、results、server 、system。其中与服务器端相关:database、server、system(永远无法修改,就是utf-8);与客户端相关:connection、client、results 。

在 MySQL 的安装目录下有一个 my.ini 配置文件,通过修改这个配置文件可以一劳永逸的解决乱码问题。在这个配置文件中 [mysql] 与客户端配置相关,[mysqld] 与服务器配置相关。默认配置如下:

  • [mysql]
  • default-character-set=utf8
  • [mysqld]
  • character-set-server=utf8

这时只需要将下的默认编码 default-character-set=utf8 改为 default-character-set=gbk ,重新启动 MySQL 服务即可。

然后还要确定PHP的编码是UTF8。

最后要确定你输入的数据的编码,只需要在你的输入页面的页头加上

1
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">

编码就变UTF8了。

这个时候编码就同一了,就不会出现乱码,为空的现象了

 

http://my.oschina.net/u/812141/blog/208996

PHP向MYSQL插入中文乱码问题解决方法

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注

此站点使用Akismet来减少垃圾评论。了解我们如何处理您的评论数据