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

原创 2001年05月25日 09:44:00
忙了几天,终于对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中拷出来的

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

忙了几天,终于对JDK1.2的JDBC中文问题有了初步的了解,虽然还有问题存在,但我想大家可能都着急了吧?:)所以就把我的初步想法先贴出来,欢迎大家补充. JDK1.2的中文问题主要是由于引入了Uni...
  • panlang
  • panlang
  • 2001年05月28日 16:17
  • 433

JDBC连接mysql处理中文时乱码的一种解决办法

近日,整合的项目需要跟一个比较老版本的mysql服务器连接,使用navicat查看,发现此mysql服务器貌似没有设置默认编码,而且从操作此mysql的部分php文件看,应该是使用的gb2312的编码...
  • cyq1984
  • cyq1984
  • 2012年08月14日 20:20
  • 7290

使用JDBC连接数据库遇到的问题,以及查找到的解决方法

JDBC(Java Data Base Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用Java语言编写的类和...
  • jslkasd
  • jslkasd
  • 2015年03月12日 09:05
  • 622

解决JDBC中文乱码问题

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

关于ArcGis开发问题总结

一、新手请教ArcGIS Engine Runtime和ArcGIS Engine Developer Kit有何区别 我毕业设计是用VC++进行地理信息系统的2次开发,需要AE,网上下载的有这...
  • e_wsq
  • e_wsq
  • 2013年04月22日 22:55
  • 802

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

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

高并发常见的解决方案

一个小型的网站,可以使用最简单的html静态页面就实现了,配合一些图片达到美化效果,所有的页面均存放在一个目录下,这样的网站对系统架构、性能的要求都很简单。随着互联网业务的不断丰富,网站相关的技术经过...
  • Ivy___
  • Ivy___
  • 2016年08月25日 16:40
  • 1948

JDBC主要API介绍

JDBC 原理 原来的 SUN 公司(现在是Oracle 公司)在开发JDBC API 时,将这些接口和类放在了两个 包中,java.sql 包和javax.sql 包中。而主要的接口和类都是在jav...
  • zzk1207
  • zzk1207
  • 2015年08月31日 08:47
  • 1539

javaee ssh框架下mysql中文乱码解决办法

1、修改my.ini文件(数据库安装根目录),改为utf8(红色箭头部分) 2、手动创建数据库                               create database db_t...
  • jingzailongxin
  • jingzailongxin
  • 2015年11月19日 15:33
  • 523

SSH开发中解决mysql数据库的乱码问题

(1)第一点要保证 就是创建数据库的时候 使用的编码方式 和连接数据库的 编码格式是一样的! (2)在web.xml文件中配置过滤器(由spring提供的过滤器) ...
  • u010870518
  • u010870518
  • 2014年12月08日 13:20
  • 1583
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:JDK1.2关于JDBC中文问题的解决方案
举报原因:
原因补充:

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