当前位置:数据库 > MySQL >>

解决MYSQL中文乱码问题三种方法

方法三

1>本文将消除乱码分为三步:

         >消除页面乱码,

         >消除从mysql教程中读出中文乱码,

         >消除插入mysql数据库教程中的中文乱码;

15>注意编码表示方式在网页特效p/jsp.html target=_blank >jsp教程与mysql中的区别,如下:

      jsp: gb2312, gbk, utf-8....

      mysql: gb2312, gbk, utf8....

关键问题:编码,建议统一为gb2312或gbk,本文使用gb2312,gbk未测试;

【step1】: 消除纯html页和jsp页在tomcat环境下运行的乱码

   这个是由于流览器无法选择编码方式造成的, 手动从ie中选择“gb2312”即可解决;也可以网页中加入meta标记或page指令;

   meta标记如下:

         <meta http-equiv="content-type" content="text/html; ch***t=gb2312">

   page指令如下:

        <%@ page language="java" contenttype="text/html; ch***t=gb2312" pageencoding="gb2312"%>

   前面说明中已经提到, meta在2k下可能不起作用(xp下时了时坏),因为简单起见,加入page指令似乎是一个一劳永逸的事情;

   总结: 加入page指令,一定可以使纯jsp页面或html页面在tomcat环境下正常显示。

【step2】: 消除从mysql数据库中读出中文的乱码

    分为两个目标: step1: 从mysql客户端查看中文正常, step2: 从网页中查看中文正常;

1: 在用sql脚本创建数据库前,设置mysql的默认编码方式为“gb2312”,

   此步可以在mysql-administrator-1.1.0-rc-win.msi中完成,或者是mysql server向导;

    这样设置完毕后再用sql 脚本创建数据库, 注意如果sql脚本中有设置字符集为latin1或utf-8的语句,一定要删除。

         已发现目前版本《在线书店》中的sql脚本中带有设置默认字符集为latin1,一定要删除!

       创建数据库完毕后,用mysql cc或mysql admin可检查所创建的数据库的字符集,如果正确,则用mysql cc或mysql admin都可以正常查看中文;

2: 一般情况下,到这一步,在网页中已经基本能正常显示中文了,但凡事总有例外,可以在数据库连接串处再特别说明一下:

       string url ="jdbc:mysql://localhost/bookstore?useunicode=true&characterencoding=gb2312";

       conn=drivermanager.getconnection(url,"root","");

   一般情况下用 string url ="jdbc:mysql://localhost/bookstore"应该就能正常显示中文。

总结:修改mysql server数据库默认字符集为“gb2312”,从mysql读出中文可正常显示;

   例外: 此时仍有可能还有乱码,如本书光盘中的《在线书店》,请参见前面的说明。

【step3】: 消除插入mysql数据库中的中文乱码

   此步比较简单,在jsp页面中加入如下代码:

          request.setcharacterencoding("gb2312");

补充:数据库,mysql教程
CopyRight © 2022 站长资源库 编程知识问答 zzzyk.com All Rights Reserved
部分文章来自网络,