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

王朝java/jsp·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

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

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航