快精灵印艺坊 您身边的文印专家
广州名片 深圳名片 会员卡 贵宾卡 印刷 设计教程
产品展示 在线订购 会员中心 产品模板 设计指南 在线编辑
 首页 名片设计   CorelDRAW   Illustrator   AuotoCAD   Painter   其他软件   Photoshop   Fireworks   Flash  

 » 彩色名片
 » PVC卡
 » 彩色磁性卡
 » 彩页/画册
 » 个性印务
 » 彩色不干胶
 » 明信片
   » 明信片
   » 彩色书签
   » 门挂
 » 其他产品与服务
   » 创业锦囊
   » 办公用品
     » 信封、信纸
     » 便签纸、斜面纸砖
     » 无碳复印纸
   » 海报
   » 大篇幅印刷
     » KT板
     » 海报
     » 横幅

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

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


前几天将数据库移到了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下载。
返回类别: 教程
上一教程: 解决SQL速度慢的方式
下一教程: TOPN 子句与SET ROWCOUNTN 之对比

您可以阅读与"实用的MYSQL中文问题的解决方案"相关的教程:
· MYSQL中文模糊检索问题的解决方式
· 关于MYSQL 4.1语言问题的完美解决方式
· MYSQL中文问题解决
· MYSQL中文排序错误的解决方式
· 关于MYSQL5改密码后不能登录问题的解答
    微笑服务 优质保证 索取样品