【在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 '你的编码';终于完了,如果对大家有用就顶下啦。不正确的地方也请指正
文章评论
共有 位脚本之家网友发表了评论我来说两句