分享
 
 
 

JDK1.2关于JDBC中文问题的解决方案

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

忙了几天,终于对JDK1.2的JDBC中文问题有了初步的了解,虽然还有问题存在,但我想大家可能都着急了吧?:)所以就把我的初步想法先贴出来,欢迎大家补充. JDK1.2的中文问题主要是由于引入了Unicode引起的(其实在1.1版本中就有了),Unicode的字符由16bit构成,关于Unicode更详细的信息有兴趣者可以到www.unicode.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 Driver(Oracle8.0.3附带). 我的第一个体会是用JDBC-ODBC桥接访问数据库中文输入有问题,我还没解决,我用的JDBCODBC Driver是JDK1.2自带的. 第二个体会是用JDBC直接联数据库,这时可能有两种情况: 1,中文输入没问题(Oracle8),即可以在SQL语句中直接写中文,如:

statement.executeUpdate("inser into tablename values("测试",....) 2,中文输入有问题(Sybase11),看错误可知是Unicode转换引起的,解决办法是将Unicode转换为ASCII形式,即一个汉字拆成两个char,用到两个类ByteToCharConverter和CharToByteConverter,在sun.io.*中,可以在JDK home\jre\lib\i18n.jar中找到,没有文档,我也实在网上找到用法的.

在输入时,用ChineseStringToAscii转换为ASCII码字串,查询时用AsciiToChineseString转换为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中拷出来的

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有