php查询mysql数据库乱码_怎么解决php数据库查询乱码问题

php数据库查询乱码的解决办法:首先在MySQL Command Line Client创建数据库;然后指定数据库的字符集,让mysql同时支持多种编码的数据库;最后对创建好的数据库进行操作即可。

bb6e64e600b73290040151183f8daee9.png

乱码解决方法

推荐:《PHP教程》

要解决乱码问题,首先必须弄清楚自己数据库用什么编码。如果没有指明,将是默认的latin1。

我们用得最多的应该是这3种字符集 gb2312,gbk,utf8。

那么我们如何去指定数据库的字符集呢?下面也gbk为例

【在MySQL Command Line Client创建数据库】mysql> CREATE TABLE `mysqlcode` (

-> `id` TINYINT( 255 ) UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY ,

-> `content` VARCHAR( 255 ) NOT NULL

-> ) TYPE = MYISAM CHARACTER SET gbk COLLATE gbk_chinese_ci;

Query OK, 0 rows affected, 1 warning (0.03 sec)

mysql> desc mysqlcode;

+---------+-----------------------+------+-----+---------+----------------+

| Field | Type | Null | Key | Default | Extra |

+---------+-----------------------+------+-----+---------+----------------+

| id | tinyint(255) unsigned | NO | PRI | | auto_increment |

| content | varchar(255) | NO | | | |

+---------+-----------------------+------+-----+---------+----------------+

2 rows in set (0.02 sec)

其中后面的TYPE = MYISAM CHARACTER SET gbk COLLATE gbk_chinese_ci;

就是指定数据库的字符集,COLLATE (校勘),让mysql同时支持多种编码的数据库。

当然我们也可以通过如下指令修改数据库的字符集alter database da_name default character set 'charset'.

客户端以 gbk格式发送 ,可以采用下述配置:SET character_set_client='gbk'

SET character_set_connection='gbk'

SET character_set_results='gbk'

这个配置就等价于 SET NAMES 'gbk'。

现在对刚才创建的数据库操作mysql> use test;

Database changed

mysql> insert into mysqlcode values(null,'php爱好者');

ERROR 1406 (22001): Data too long for column 'content' at row 1

没有指定字符集为gbk,插入时出错mysql> set names 'gbk';

Query OK, 0 rows affected (0.02 sec)

指定字符集为 gbkmysql> insert into mysqlcode values(null,'php爱好者');

Query OK, 1 row affected (0.00 sec)

插入成功mysql> select * from mysqlcode;

+----+-----------+

| id | content |

+----+-----------+

| 1 | php爱好着 |

+----+-----------+

1 row in set (0.00 sec)

在没有指定字符集gbk时读取也会出现乱码,如下mysql> select * from mysqlcode;

+----+---------+

| id | content |

+----+---------+

| 1 | php??? |

+----+---------+

1 row in set (0.00 sec)

【在phpmyadmin创建数据库,并指定字符集】

表类型根据自己需要选,这里选MyISAM(支持全文检索);

整理选择 gbk_chinese_ci 也就是gbk字符集

gbk_bin 简体中文, 二进制。gbk_chinese_ci 简体中文, 不区分大小写。

在刚才创建的数据库插入数据库

再浏览时发现是乱码

为什么呢?是因为数据库为gbk字符集,而我们操作时没有指定为gbk

回到数据库首页

可以看到 mysql 连接校对默认的latin1_bin。我们将其改为gbk_chinese_ci

再插入一条数据。看,这条已经正常了

【解决php读取数据库乱码】

仍以数据库mysqlcode为例<?php

$conn = mysql_connect("localhost","root","89973645");

mysql_query("set names 'gbk'");//这就是指定数据库字符集,一般放在连接数据库后面就系了

mysql_select_db("test");

$sql = "select * from mysqlcode";

$result = mysql_query($sql,$conn);

?>

mysql 字符编码
id内容

echo "

".$row['id']."".$row['content']."";

}?>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值