关于php与mysql的一些编码乱码问题

首先把话说在这里,我写这篇仅对于有我这种情况的。

我的情况是这样的:

1.接收的数据和传输的数据都是utf8的格式,这个可以用一个函数来判断编码格式

<?php
     $string = "你好";
     $encode = mb_detect_encoding($string,array("ASCII",'UTF-8',"GB2312","GBK",'BIG5')); 
     echo $encode;
?>

2.从数据库里取出来的数据不会乱码。

对的,真是奇怪了,对吧,数据库里查看数据是乱码,但是读取出来却没有乱码。这个马上就让我联想到,肯定是数据库本身的问题。

我用的管理数据库的工具是Navicat for MySQL。里面修改了之后,还是没用。

解决方案:

1.首先你要确定你的数据库的编码格式。

这里在数据库里手动输入

show variables like 'character%';

这里会出现一张类似这样的表。在没用修改之前,character_set_server    这里是latin1编码,这是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       | D:\Server\wamp\bin\mysql\mysql5.6.17\share\charsets
\ |
+--------------------------+----------------------------------------------------
--+

这里就要开始修改character_set_server了,其他地方的修改都挺简单的,网上的一些教程都有效,就是这个Server有点小问题。

一、windows系统下面
1、中止mysql服务
2、在mysql的安装目录下找到my.ini,如果没有就把my-medium.ini复制为一个my.ini即可
3、打开my.ini以后,在[client]和[mysqld]下面均加上default-character-set=utf8,保存并关闭.
(mysqld中增加如果出错,可以试 character-set-server=utf8)
4、启动mysql服务

这个方法,亲测有效。linux系统的我就不清楚了。我把方法贴出来,有兴趣的可以去试一试。

二、linux系统下面
1、中止mysql服务(bin/mysqladmin -u root shutdown)
2、在/etc/下找到my.cnf,如果没有就把mysql的安装目录下的support-files目录下的my-medium.cnf复制到/etc/下并改名为my.cnf即可
3、打开my.cnf以后,在[client]和[mysqld]下面均加上default-character-set=utf8,保存并关闭
4、启动mysql服务(bin/mysqld_safe &)

以上修改一劳永逸,mysql一切相关的默认编码均为utf-8了,创建新表格时无需再次设置。(www.jbxue.com 脚本学堂)

提示:当前 数据库中已经存在的数据仍保留现有的编码方式,因此需要自行转码。


然后修改之后,再次加入数据,ok,成功显示中文。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值