JDBC中文处理

原创 2001年05月05日 01:30:00
我们在做一个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
上也成功。

JDBC查询条件中包含中文,无查询结果(编码问题)

JDBC查询条件中包含中文,无查询结果,编码问题
  • catharine12
  • catharine12
  • 2015年10月09日 00:12
  • 1369

解决JDBC中文乱码问题

由于编码字符集的不同通常容易导致中文乱码问题,根据以下做法一步一步设置将可解决中文乱码问题。对于从数据库提取中文或者向数据库录入中文均可实现。本文使用Navicate管理数据库,eclipse管理编写...
  • u014071802
  • u014071802
  • 2014年04月30日 11:05
  • 3357

jdbc操作非中文字符集oracle数据库导致的中文字符读写乱码的解决方案

oracle数据库向来是一个麻烦的数据库,要不它的DBA怎么就那么值钱呢,呵呵。中文的乱码问题也是一个比较头疼的问题,在odbc的连接中,可以通过设置客户端的字符集(修改注册表)来解决中文问题。而通过...
  • huangyuanmu
  • huangyuanmu
  • 2013年11月18日 13:23
  • 1852

sql语句里有中文字符,JDBC查询不出来结果

sql语句里有中文字符,JDBC查询不出来结果,将连接的url加入useUnicode=true&characterEncoding=UTF-8,如 (jdbc:mysql://localh...
  • lalalaas123
  • lalalaas123
  • 2016年12月28日 11:04
  • 951

jdbc 写入mysql 中文乱码

解决办法:      1.创建数据库时将数据库的缺省字符集指定为gbk。建议用工具(如phpmyadmin等)     2.修改Client默认字符集为UTF-8。windows下在mysql安装...
  • u013076044
  • u013076044
  • 2015年09月11日 21:00
  • 1410

解决java 向jdbc中存储数据中文乱码问题

加上后缀“?useUnicode=true&characterEncoding=utf8”
  • qq_21434959
  • qq_21434959
  • 2016年09月21日 22:32
  • 1046

使用JDBC处理大数据和大文本

使用JDBC处理大数据和大文本 使用JDBC处理大数据 基本概念:大数据也称为LOB(Large Objects),LOB又分为:clob和blob Colb用于存储大文本 Blob 用于存储...
  • w_l_j
  • w_l_j
  • 2011年11月17日 15:26
  • 1482

SQL语句中出现中文字符时JDBC报错,解决办法

(1)当SQL中出现汉字时,直接执行SQL命令,可以得到正确结果(2)当使用JDBC查询时,报错严重: Servlet.service() for servlet [springMvc] in con...
  • chengyuqiang
  • chengyuqiang
  • 2017年09月19日 10:05
  • 571

JDBC处理大数据(大文本的存储和读取)

JDBC处理大数据(大文本的存储和读取) 1. 基本概念:大数据也称之为LOB(Large Objects),LOB又分为:clob和blob •   clob用于存储大文本。Text •   ...
  • Java958199586
  • Java958199586
  • 2011年11月17日 12:13
  • 2775

04.JDBC编程之指定变量&批处理

转载请标明出处:http://blog.csdn.net/u012637501 一、指定SQL语句中的变量 1.PreparedStatement接口     PreparedStateme...
  • u012637501
  • u012637501
  • 2015年04月28日 18:59
  • 822
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:JDBC中文处理
举报原因:
原因补充:

(最多只允许输入30个字)