小结下MySQL中文乱码,phpmyadmin乱码,php乱码 产生原因及其解决方法
更新时间:2007年09月02日 22:07:53 作者:
【在phpmyadmin创建数据库,并指定字符集】
表类型根据自己需要选,这里选MyISAM(非事务);
整理选择 gbk_chinese_ci 也就是gbk字符集
gbk_bin 简体中文, 二进制。gbk_chinese_ci 简体中文, 不区分大小写。
在刚才创建的数据库插入数据库
再浏览时发现是乱码
为什么呢?是因为数据库为gbk字符集,而我们操作时没有指定为gbk
回到数据库首页
可以看到 mysql 连接校对默认的latin1_bin。我们将其改为gbk_chinese_ci
再插入一条数据。看,这条已经正常了
【解决php读取数据库乱码】
仍以数据库mysqlcode为例
复制代码 代码如下:
<?php
//php爱好者站教程 http://www.phpfans.net
$conn = mysql_connect("localhost","root","");
mysql_query("set names 'gbk'");//这就是指定数据库字符集,一般放在连接数据库后面就系了
mysql_select_db("test");
$sql = "select * from mysqlcode";
$result = mysql_query($sql,$conn);
?>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>mysql 字符编码</title>
</head>
<body>
<table width="300" height="32" border="1" align="center" cellpadding="0" cellspacing="0">
<tr>
<td width="71" align="center">id</td>
<td width="229" align="center">内容</td>
</tr>
<?php while($row = mysql_fetch_assoc($result)){
echo "
<tr>
<td align=\"center\">".$row['id']."</td>
<td>".$row['content']."</td>
</tr>";
}?>
</table>
</body>
</html>
<?php mysql_free_result($result);?>
如果我们将mysql_query("set names 'gbk'");注释掉,肯定时乱码
加上那句又正常了
注意: set names 必须在连接数据库之后,执行sql语句之前!
一句话
你数据库用什么编码,在对数据库操作之前就set names '你的编码';
终于完了,如果对大家有用就顶下啦。不正确的地方也请指正
您可能感兴趣的文章:
- MySQL中文乱码问题解决方案
- 解决Mysql5.7中文乱码的问题
- 数据库 MySQL中文乱码解决办法总结
- Mysql 下中文乱码的问题解决方法总结
- Mac Mysql数据库中文乱码问题解决
- Mysql彻底解决中文乱码问题的方案(Illegal mix of collations for operation)
- MySql安装步骤图文教程及中文乱码的解决方案
- MYSQL数据库使用UTF-8中文编码乱码的解决办法
- Mysql中文乱码问题的最佳解决方法
- 解决mysql5中文乱码问题的方法
- MySQL字符集 GBK、GB2312、UTF8区别 解决MYSQL中文乱码问题
- mysql 中文乱码 解决方法集锦
- MySQL中文乱码问题的解决
- 彻底解决MySQL使用中文乱码的方法
相关文章
浅析PHP原理之变量(Variables inside PHP)
我前面的文章中已经讲过,PHP的执行是通过Zend engine(ZE, Zend引擎), ZE是用C编写的,大家都知道C是一个强类型语言,也就是说,在C中所有的变量在它被声明到最终销毁,都只能保存一种类型的数据。 那么PHP是如何在ZE的基础上实现弱类型的呢2013-08-08phpmyadmin配置文件现在需要绝密的短密码(blowfish_secret)的2种解决方法
安装完成phpmyadmin之后,再在浏览器里输入:http://localhost/phpmyadmin这时能看到phpmyadmin的管理页面,不过会提示:“配置文件现在需要绝密的短密码(blowfish_secret)。”2014-05-05
最新评论