免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2184 | 回复: 9
打印 上一主题 下一主题

PHP+MYSQL编程问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-03-08 16:00 |只看该作者 |倒序浏览
请教php+mysql,数据库是中文,PHP也能显示中文,但用mysql_fetch_array调出来的时候,就不能显示中文。
不知那里有问题,请指教。
平台:winxp
软件: Appser2.5.6

论坛徽章:
0
2 [报告]
发表于 2007-03-08 16:12 |只看该作者
具体什么编码?

论坛徽章:
0
3 [报告]
发表于 2007-03-08 22:58 |只看该作者
在winxp下,安装appserv2.5.8
在安装到mysql时,charset默认选utf8 unicode

通过PHPadmin配置mysql,生成一个新库test1,和表test,有两个段位:name和age
有两个记录:第一个记录是啊啊和30;第二个记录是aaa和20。
下面程序用IE打开,显示如下
Connected successfully
?? 30
aaa 30
为什么中文啊啊用??代替了。

不明白,请指教。


<?php

$mysql_server_name = "127.0.0.1";
$mysql_user = "root";
$mysql_password = "750722";
$mysql_database = "test1";

/* Connecting, selecting database */
$link = mysql_connect($mysql_server_name, $mysql_user, $mysql_password)
                        or die('Could not connect : ' . mysql_error($link));
echo 'Connected successfully';

mysql_select_db($mysql_database, $link)
    or die('Could not select database');

/* Issue SQL query */
$query = 'SELECT * FROM test';
$result = mysql_query($query, $link) or die('Query failed : ' . mysql_error($link));

/* Printing results in HTML */
echo "<table border=\"1\">\n";
while ($row = mysql_fetch_array($result, MYSQL_ASSOC)) {
    echo "\t<tr>\n";
    foreach ($row as $col_value) {
        echo "\t\t<td>$col_value</td>\n";
    }
    echo "\t</tr>\n";
}
echo "</table>\n";

/* Free result set */
mysql_free_result($result);

/* Close connection */
mysql_close($link);

?>

论坛徽章:
0
4 [报告]
发表于 2007-03-08 23:42 |只看该作者
很显然你的数据库字段编码类型设置错误,导致中文变成乱码进行存储了

论坛徽章:
0
5 [报告]
发表于 2007-03-09 07:49 |只看该作者
没有啊,通过PHPadmin看数据库存储的是中文啊。就算我把表换了GB2312,也不行。

论坛徽章:
0
6 [报告]
发表于 2007-03-09 08:50 |只看该作者
原帖由 wanfei 于 2007-3-9 07:49 发表
没有啊,通过PHPadmin看数据库存储的是中文啊。就算我把表换了GB2312,也不行。



alter datebase 数据库名 CHARACTER SET gb2312

论坛徽章:
0
7 [报告]
发表于 2007-03-09 10:35 |只看该作者
谢谢楼上的,好像还是没有用

论坛徽章:
0
8 [报告]
发表于 2007-03-09 11:41 |只看该作者
后来,我在命令行,进入mysql,用select * from test语句,看记录也是乱码,但通过PHPadmin就没有问题,真实郁闷。后来,我建立n个test库,换了gb2312_bin,gb2312_chinese_ci,gbk,utf8_unicode好多种,都试了试,不知,语句出来就是?。

论坛徽章:
0
9 [报告]
发表于 2007-03-09 12:34 |只看该作者
谢谢,此问题,已经解决了。谢谢google。
mysql_query("SET character_set_connection=gb2312, character_set_results=gb2312, character_set_client=binary");
加上这个语句就可以了。

论坛徽章:
0
10 [报告]
发表于 2007-03-09 13:20 |只看该作者
通过mysql命令行,输入select * from table前,输入命令 set NAMES 'gb2312';就能正常显示中文了,谢谢各位了。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP