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

原创 2004年10月08日 15:22:00

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

mysql安装及遇到的问题

1、mysql安装教程 MySQL下载安装、配置与使用(win7x64) http://jingyan.baidu.com/article/597035521d5de28fc00740e6.htm...
  • tanhoqi451
  • tanhoqi451
  • 2016年09月28日 01:20
  • 158

JDBC连接mysql处理中文时乱码的一种解决办法

近日,整合的项目需要跟一个比较老版本的mysql服务器连接,使用navicat查看,发现此mysql服务器貌似没有设置默认编码,而且从操作此mysql的部分php文件看,应该是使用的gb2312的编码...
  • cyq1984
  • cyq1984
  • 2012年08月14日 20:20
  • 7290

java连接mysql的方法及问题解决方案

java连接mysql数据库简单操作
  • qq_26071477
  • qq_26071477
  • 2016年06月08日 15:10
  • 1065

Mysql常见的几个错误问题及解决方法:

Mysql常见的几个错误问题及解决方法:1.问题: mysql DNS反解:skip-name-resolve错误日志有类似警告:120119 16:26:04 [Warning] IP addres...
  • zfy1355
  • zfy1355
  • 2016年11月30日 10:43
  • 842

MySQL主从问题及解决方案

参考"高性能MySQL一书"主库意外关闭:如果没有设置sync_binlog选项,就可能在数据库崩溃前没将最后的部分二进制事件刷新至磁盘,备库IO系线程可能一直处于读不到未写入磁盘的状态.当主库重新启...
  • wufeng4552
  • wufeng4552
  • 2015年05月22日 18:22
  • 1071

mysql中文问题最佳解决方案

1、设置在MySQL配置文件my.ini文件中 default-character-set=utf8;2 、建立数据库create database out_member; use out_membe...
  • thinker28754
  • thinker28754
  • 2008年03月19日 11:07
  • 467

解决方案:mysql的中文问题(开发语言:Java)

论坛中,mysql的中文问题甚多,现结合已有帖子,和我一下午的测试,现将解决方案与大家共享之。======版本======mysql:  1.5jkd: 1.5===== mysql======修改安...
  • archeng
  • archeng
  • 2006年11月28日 16:18
  • 353

android studio乱码解决方案

我们在使用android studio的时候,当打开别人的工程的时候,时长会碰到乱码的问题,当把编码格式转成 GBK的时候,乱码消失了,可是这样就不能再转回UTF-8了,怎么办呢? 这时候,微软自带的...
  • danse_guang
  • danse_guang
  • 2015年07月21日 19:50
  • 261

mysql存储中文字符乱码

在使用原生的JDBC的同学不知道有没有遇到过类似的问题mysql中的中文乱码的问题,首先表现就是我们存储的时候参数明明使用的是中文,但是Java代码执行完成后数据库中变成了  “???” 也就是中文乱...
  • lly576403061
  • lly576403061
  • 2016年09月20日 11:04
  • 1077

Linux系统下永久解决mysql存储中文问题

今天突然想起搭建网站的话,MySql数据库里面需要存储中文。所以就开始鼓捣起如何实现MySql存储中文这个问题。    网上也有其他解决方法,但是很多是一次性的,我希望可以实现永久解决MySql存储中...
  • panjican
  • panjican
  • 2015年11月02日 19:25
  • 1028
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:实用的MySQL中文问题的解决方案
举报原因:
原因补充:

(最多只允许输入30个字)