Java资源网

| JAVA基础 | 环境配置 | JDBC | 线程技术 | Socket编程 | JavaMail | JAVA与XML | 设计模式 | 技术新闻 | Java认证 | 程序人生 软件下载
| JSP&Servlet | Spring | Struts | Hibernate | JBuilder | Eclipse | WebService | EJB技术 | J2ME开发 | 应用服务器 | JXTA | Ajax
Articles search文章搜索
   关键字:
   类 别:
       
New download 最新下载
· [组件]HTML Parser 1.5
· [教程]WebSphere Studio应用教程
· [组件]JDom 1.0
· [工具]Junit3.8.1
· [教程]EJB编程及J2EE系统架构和设计
· [教程]EJB教程
· [教程]J2EE Tutorial中文版
· [教程]Java编程思想2(英文)
· [教程]java编程思想(完整版)
· [教程]Java网络编程
New articles 最新文章
· 设计移动 Web 服务
· 解析XML的时候完全忽略DTD
· 理解XML Schema XML Schema 初步
· 标签库的深入研究
· 提升JSP应用程序的七大绝招
· 如何使用JDOM对XML文件进行操作
· 处理XML字符串中特殊字符
· 利用Digester把XML转换成为Java对象
· 使用WebService 和RMI远程协作
· 使用Axis开发Web Service程序
Articles top 热门文章
· Eclipse基础--plugin插件安装(6644)
· eclipse+tomcat+lomboz的安装配置说明(4774)
· Java程序员就业前景(4584)
· Windows下JAVA环境变量的设置祥解(3788)
· Tomcat下JSP、Servlet和JavaBean环境的配置(3716)
· 使用links方式安装Eclipse插件(3698)
· 一个老程序员的心理话(3533)
· linux下jdk的安装与配置(3459)
· 初学者入门:Structs中基本配置入门(3334)
· Eclipse 运行命令行参数大全(3084)
您的位置:首页>>JDBC>>实用的MySQL中文问题的解决方案
实用的MySQL中文问题的解决方案
2005-08-29   来源:CSDN  作者:realclimax

    前几天将数据库移到了MySQL上,转移过程中发现MySQL5.0已经改进了很多。真是不用不知道,一用吓一跳啊!不过MySQL的中文问题还是搞得人很头大,不过最终我们还是总结出了一个比较好的解决方案。

        一、Web服务器采用resin,操作系统采用Windows系列,连接数据库使用数据源方式。在resin/conf/resin.conf中加入如下代码(位于<caucho.com>和</caucho.com>之间):

<resource-ref>
  <res-ref-name>jdbc/test</res-ref-name>
  <res-type>javax.sql.DataSource</res-type>
  <init-param driver-name="com.mysql.jdbc.jdbc2.optional.MysqlConnectionPoolDataSource"/>
  <init-param url="jdbc:mysql://127.0.0.1:3306/test"/>
  <init-param user="root"/>
  <init-param password=""/>
  <init-param useUnicode="true"/>
  <init-param max-connections="100"/>
  <init-param max-idle-time="30"/>
</resource-ref>
注:相关参数请自行改变


        二、在连接数据库时使用如下代码建立连接:

        Context env = new InitialContext();

        DataSource pool = (DataSource) env.lookup("java:comp/env/jdbc/erms");
        if (pool == null)
           throw new Exception("jdbc/erms is an unknown DataSource");
        conn = pool.getConnection();
        stmt = conn.createStatement();

        三、编写如下两个静态方法:

public static String getstr(String str)
{
      try {
        String temp_p = str;
        byte[] temp_t = temp_p.getBytes("ISO8859-1");
        String temp = new String(temp_t);
        return temp;
      }
      catch (UnsupportedEncodingException ex) {
       System.out.println(ex);
       return "";
      }

}

 public static String ISOConverter(String str)
{
       if(str==null)
      {
              str="";
      }
      else{
             try{
                  str=new String(str.getBytes("GBK"),"ISO8859_1");
             }
             catch(Exception ex){
                  ex.printStackTrace();
            }
       }
       return str;
}

        在执行一个sql语句前,对将要执行的sql语句执行ISOConverter(sql)方法,可以将中文正常的写入MySQL(MySQL中存的是中文,可以使用第三方工具查看);而从数据库中取出数据后,对中文数据字符串使用getstr(cnString)方法,即可得到正确中文的字符串。

        需要注意的是,MySQL不需要进行其他任何设置。而除了以上指出的两处需要转换字符编码,没有其他需要转换字符编码的地方了。

        MySQL5.0以及相应JDBC可在http://dev.mysql.com/downloads下载。

  --相关文章--
· 通过JDBC连接oracle数据库的十大技巧 (2007-04-13)
· 第一个JDBC程序 (2007-04-13)
· 符合oo惯例的表现层控制 (2007-04-13)
· 用hibernate对递归数据的操作 (2007-04-13)
· 煮酒论英雄nbsp;-nbsp;漫谈Java数据库存取技术 (2007-04-13)
· 利用weblogic的数据源作为hibernate的数据源的例子 (2007-04-13)

版权所有©2005-2006 JAVA资源网 渝ICP备05007591号 虚拟主机 | 关于我们 | 联系方式 | 广告业务 | 网站地图 | 友情链接