欢迎光临
我们一直在努力

JDK1.2关于JDBC中文问题的解决方案-JSP教程,Java技巧及代码

建站超值云服务器,限时71元/月

发信人: hht (duke), 信区: java
标  题: jdk1.2关于jdbc中文问题的解决方案&re yzhang
发信站: 网易虚拟社区 (mon jan 11 13:29:43 1999), 转信

忙了几天,终于对jdk1.2的jdbc中文问题有了初步的了解,虽然还有问题存在,但我
想大家可能都着急了吧?:)所以就把我的初步想法先贴出来,欢迎大家补充.
jdk1.2的中文问题主要是由于引入了unicode引起的(其实在1.1版本中就有了),u
nicode的字符由16bit构成,关于unicode更详细的信息有兴趣者可以到www.unico
de.org查阅,在1.0版本中,一个中文是由两个char(8bit)组成的,而1.1以上版本中
是由一个char(16bit)组成的.这一点大家可以用system.out.println(s.length(
))语句来证实,其中s为中文字串.
现在来说说解决办法,首先声明这些结果只是在我的环境里测试通过,如果在各位
的环境里有问题,请务必告知.
我的环境是jdk1.2+win95+sybase jdbc driver(powerj2.5附带)+oracle jdbc d
river(oracle8.0.3附带).
我的第一个体会是用jdbc-odbc桥接访问数据库中文输入有问题,我还没解决,我用
的jdbcodbc driver是jdk1.2自带的.
第二个体会是用jdbc直接联数据库,这时可能有两种情况:
1,中文输入没问题(oracle8),即可以在sql语句中直接写中文,如:
statement.executeupdate("inser into tablename values("测试",….)
2,中文输入有问题(sybase11),看错误可知是unicode转换引起的,解决办法是将u
nicode转换为ascii形式,即一个汉字拆成两个char,用到两个类bytetocharconve
rter和chartobyteconverter,在sun.io.*中,可以在jdk home\jre\lib\i18n.jar
中找到,没有文档,我也实在网上找到用法的.
在输入时,用chinesestringtoascii转换为ascii码字串,查询时用asciitochines
estring转换为unicode字串.源代码如下:
public static string asciitochinesestring(string s) {
    char[] orig = s.tochararray();
    byte[] dest = new byte[orig.length];
    for (int i=0;i<orig.length;i++)
      dest[i] = (byte)(orig[i]&0xff);
    try {
      bytetocharconverter tochar = bytetocharconverter.getconverter("g
b2312");
      return new string(tochar.convertall(dest));
    }
    catch (exception e) {
      system.out.println(e);
      return s;
    }
  }

  public static string chinesestringtoascii(string s) {
    try {
      chartobyteconverter tobyte = chartobyteconverter.getconverter("g
b2312");
      byte[] orig = tobyte.convertall(s.tochararray());
      char[] dest = new char[orig.length];
      for (int i=0;i<orig.length;i++)
        dest[i] = (char)(orig[i] & 0xff);
      return new string(dest);
    }
    catch (exception e) {
      system.out.println(e);
      return s;
    }
  }
主程序片断如下:
try{
statement stmt;
class.forname("com.sybase.jdbc.sybdriver");
connection conn =drivermanager.getconnection ("jdbc:sybase:tds:202.9
7.228.249:5000/todo","sa","");   
stmt = conn.createstatement ();
string s="何海涛";  
s=chinesestringtoascii(s);
     stmt.executeupdate ("insert into russia values("+s+",1,1,"+s+
")");
}catch(exception e){
system.out.println(e);
}
在读数据时用string s=asciitochinesestring(rs.getstring(1))
——————–
因为手头只能对这两种数据库进行测试,所以对别的数据库可能出现的情况不能保
证.不过我估计基本是上面这两种情况.另外,用jdk1.2有的公司提供的driver也升
级了,比如sybase原来的driver就不好使.原理就是这样,在实际操作中要靠自己摸
索了.上面两个方法参考了台湾某bbs的一篇文章.
另外,yzhang不知你要的是什么版本,你可以在jconnect软件安装的目录下找jdbc
driver包,可能的格式是zip或jar,把他拷出来就行了.我的就是从powerj中拷出
来的

赞(0)
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » JDK1.2关于JDBC中文问题的解决方案-JSP教程,Java技巧及代码
分享到: 更多 (0)

相关推荐

  • 暂无文章