分享
 
 
 

JDBC中的中文处理

王朝other·作者佚名  2008-05-31
窄屏简体版  字體: |||超大  

我们在做一个Java的应用,不可避免地要处理中文。经过

艰苦的探索,目前有一些进展,找到了一些解决方法,但仍然

面临着无法解决的问题。在此作一整理,希望对大家有所帮助,

同时请各位高手帮忙考虑我们的问题。

Email: sailor@mailserv.stu.edu.cn

背景:

JDK 1.15

VCafe 2.0

JPadPro

SERVER:

NT IIS

Sybase System 10

JDBC: Jconnect

CLIENT:

Browser: Netscape 4.04 + Patch

PWin95 & Pwin98 Beta3

CLASS文件存放在 SERVER,由BROWSER 运行APPLET,APPLET只

起调入FRAME类主程序的作用。界面包括Text field, Text Area,

List, Choice 等。

一,取中文

用JDBC执行SELECT语句从SERVER取数据(中文)后,将数据

用APPEND方法加到TEXT AREA(TA),不能正确显示。但加到

LIST中时,则大部分汉字可正确显示。

处理:将数据按“ISO-8859-1”格式转为字节数组,再按系统

缺省编码格式(default character encoding)转为STRING,即可在TA和LIST中正确显示。

程序段如下:

dbstr2 = results.getString(1);

//*********************************************************************

// After read result from Database server, Convert the result string.

dbbyte1 = dbstr2.getBytes("iso-8859-1");

dbstr1 = new String(dbbyte1);

//*********************************************************************

二,写中文到DB

处理方式与以上相逆,先将SQL语句按DEFAULT CHARACTER ENCODING

转为字节数组,再按ISO-8859-1转为STRING,然后送执行,

则中文信息可正确写入DB。

sqlstmt = tf_input.getText();

//*****************************************************************************

// Before send statement to Database server, Convert sql statement.

dbbyte1 = sqlstmt.getBytes();

sqlstmt = new String(dbbyte1,"iso-8859-1");

//*****************************************************************************

_stmt = _con.createStatement();

_stmt.executeUpdate(sqlstmt);

。。。。。。

问题:

以上方法当本地客户机上存在CLASSPATH指向JDK的CLASSES。ZIP

时(称为A情况),可正确运行。

但假如客户机只有Browser,没有JDK和CLASSPATH时

(称为B情况),则汉字无法正确转换。

我们的分析:

1,

经过测试,在A情况下,程序运行时系统的default character

encoding = "GBK" or "GB2312".

在B情况下,程序启动时,Browser 的JAVA CONSOLE中出现

如下信息:

can´t find resource for

sun.awt.windows.awtLocalization_zh_CN

然后系统的

default characterencoding = "8859-1".

2,

假如在转换字符串时不采用default character encoding,

而是直接采用“GBK”或“GB2312”,则在A情况下仍然可正常,

在B情况下,系统出现错误:UnsupportedEncodingException。

3,

在本地客户机上,我把JDK的CLASSES。ZIP解压后,放在另一个

目录中,CLASSPATH只包含该目录。然后逐步删除目录中的CLASS

文件,一边运行测试程序,最后发现在一千多个CLASS文件中,

只有一个是不可缺少的,该文件是:

sun.io.CharToByteDoubleByte.class

我将该文件拷到SERVER端和其它的类放在一起,并在程序的开头

IMPORT它,仍然在B情况下无法正常。

4,

在A情况下,假如在CLASSPTH中去掉

sun.io.CharToByteDoubleByte.class,则程序运行时,

测得default character encoding为“8859-1”,否则为

GBK 或GB2312。

5,

分析BROWSER程序NETSCAPE目录下的文件

/program/java/classes/java40.jar, 发现其中没有包括

sun.io.CharToByteDoubleByte.class,

不知这是需要升级,还是有其它方法可以解决? 盼望各位高手指导!Email: sailor@mailserv.stu.edu.cn

--

※ 来源:?BBS 水木清华站 bbs.net.tsinghua.edu.cn?[FROM: DHCP159_158.STU]

发信人: barebell (小心), 信区: Java

标 题: Re: ● ● JDBC中文处理:方法与问题

发信站: BBS 水木清华站 (Tue May 19 22:38:19 1998) WWW-POST

现在我们取得的一点小小进展,在转换字符串时不采用default character

encoding,而是直接采用“GBK”或“GB2312”,在情况A和B底下,从DB取数据

都没有问题,但是写中文到DB也采用“GBK”或“GB2312”时,情况B仍是出错的。

发信人: mah (chip), 信区: Java

标 题: 通过jdbc driver获取数据库中文信息揭密

发信站: BBS 水木清华站 (Tue Aug 11 20:42:16 1998) WWW-POST

当我们使用老外公司开发的jdbc第四类driver获取数据库中文信息时,常会出现乱码现象

,如????D.

解决办法1:

使用interface ResultSet的方法getBytes()得到一byte[],然后由此byte[]数组产生一

新的

String,可获得正确的汉字,但此方法有一定的局限性,在某些driver上可以实现,如

weblogic公司

开发的fastforward产品。另此种方法不规范,根据sun jdbc的标准varchar和var推荐用

getString()

方法来获取。

解决办法2:

使用interface ResultSet的方法getString(),这时我们得到的String一定是乱码,如何

解决,

String temp = result.getString (s);

if (temp != null) {

byte[] b = temp.getBytes ("8859_1");

temp = new String (b);

此时的temp一定是正确的中文,,,,,,此种方法我在sybase公司开发的jconnect4上

实验成功,在fastforward

上也成功。

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