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

怎么解决php数据库查询乱码问题,数据库,字符集,乱码,操作,简体中文

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

易采站长站,站长之家为您整理了怎么解决php数据库查询乱码问题的相关内容。

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

346555cc925dd59acee08713bdcbae04.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 changedmysql> 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内容
".$row['id']."".$row['content']."
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值