转至繁体中文版     | 网站首页 | 图文教程 | 资源下载 | 站长博客 | 图片素材 | 武汉seo | 武汉网站优化 | 
最新公告:     敏韬网|教学资源学习资料永久免费分享站!  [mintao  2008年9月2日]        
您现在的位置: 学习笔记 >> 图文教程 >> 数据库 >> MySql >> 正文
实用的MySQL中文问题的解决方案         ★★★★

实用的MySQL中文问题的解决方案

作者:闵涛 文章来源:闵涛的学习笔记 点击数:1487 更新时间:2009/4/22 20:49:10

        前几天将数据库移到了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下载。


[聊天工具]实用的MSN新标签 MSN朋友__天极Yesky  [Web开发]实用的Javascript类库表格排序
[Web开发]实用的Javascript网页特效实例代码片段  
教程录入:mintao    责任编辑:mintao 
  • 上一篇教程:

  • 下一篇教程:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
      注:本站部分文章源于互联网,版权归原作者所有!如有侵权,请原作者与本站联系,本站将立即删除! 本站文章除特别注明外均可转载,但需注明出处! [MinTao学以致用网]
      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)

    同类栏目
    · Sql Server  · MySql
    · Access  · ORACLE
    · SyBase  · 其他
    更多内容
    热门推荐 更多内容
  • 没有教程
  • 赞助链接
    更多内容
    闵涛博文 更多关于武汉SEO的内容
    500 - 内部服务器错误。

    500 - 内部服务器错误。

    您查找的资源存在问题,因而无法显示。

    | 设为首页 |加入收藏 | 联系站长 | 友情链接 | 版权申明 | 广告服务
    MinTao学以致用网

    Copyright @ 2007-2012 敏韬网(敏而好学,文韬武略--MinTao.Net)(学习笔记) Inc All Rights Reserved.
    闵涛 投放广告、内容合作请Q我! E_mail:admin@mintao.net(欢迎提供学习资源)

    站长:MinTao ICP备案号:鄂ICP备11006601号-18

    闵涛站盟:医药大全-武穴网A打造BCD……
    咸宁网络警察报警平台