⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 0037.htm

📁 学习java必备书籍
💻 HTM
字号:
<html>

<head>
<title>新时代软件教程:操作系统 主页制作 服务器 设计软件 网络技术 编程语言 文字编辑</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<style>
<!--
body, table {font-size: 9pt; font-family: 宋体}
a {text-decoration:none}
a:hover {color: red;text-decoration:underline}
.1  {background-color: rgb(245,245,245)}
-->
</style>
</head>
<p align="center"><script src="../../1.js"></script></a>
    <p align="center"><big><strong>JDK1.2关于JDBC中文问题的解决方案</strong></big></p>

<div align="right">---摘自互联网</div>

<br>
忙了几天,终于对JDK1.2的JDBC中文问题有了初步的了解,虽然还有问题存在,但我 <br>
想大家可能都着急了吧?:)所以就把我的初步想法先贴出来,欢迎大家补充. <br>
JDK1.2的中文问题主要是由于引入了Unicode引起的(其实在1.1版本中就有了),U <br>
nicode的字符由16bit构成,关于Unicode更详细的信息有兴趣者可以到www.unico <br>
de.org查阅,在1.0版本中,一个中文是由两个char(8bit)组成的,而1.1以上版本中 <br>
是由一个char(16bit)组成的.这一点大家可以用System.out.println(s.length( <br>
))语句来证实,其中s为中文字串. <br>
现在来说说解决办法,首先声明这些结果只是在我的环境里测试通过,如果在各位 <br>
的环境里有问题,请务必告知. <br>
我的环境是JDK1.2+Win95+Sybase JDBC Driver(PowerJ2.5附带)+Oracle JDBC D <br>
river(Oracle8.0.3附带). <br>
我的第一个体会是用JDBC-ODBC桥接访问数据库中文输入有问题,我还没解决,我用 <br>
的JDBCODBC Driver是JDK1.2自带的. <br>
第二个体会是用JDBC直接联数据库,这时可能有两种情况: <br>
1,中文输入没问题(Oracle8),即可以在SQL语句中直接写中文,如: <br>
statement.executeUpdate(&quot;inser into tablename values(&quot;测试&quot;,....) <br>
2,中文输入有问题(Sybase11),看错误可知是Unicode转换引起的,解决办法是将U <br>
nicode转换为ASCII形式,即一个汉字拆成两个char,用到两个类ByteToCharConve <br>
rter和CharToByteConverter,在sun.io.*中,可以在JDK home\jre\lib\i18n.jar <br>
中找到,没有文档,我也实在网上找到用法的. <br>
在输入时,用ChineseStringToAscii转换为ASCII码字串,查询时用AsciiToChines <br>
eString转换为Unicode字串.源代码如下: <br>
public static String AsciiToChineseString(String s) { <br>
&nbsp;&nbsp;&nbsp;&nbsp;char[] orig = s.toCharArray(); <br>
&nbsp;&nbsp;&nbsp;&nbsp;byte[] dest = new byte[orig.length]; <br>
&nbsp;&nbsp;&nbsp;&nbsp;for (int i=0;i&lt;orig.length;i++) <br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;dest[i] = (byte)(orig[i]&amp;0xFF); <br>
&nbsp;&nbsp;&nbsp;&nbsp;try { <br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;ByteToCharConverter toChar = ByteToCharConverter.getConverter(&quot;g <br>
b2312&quot;); <br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return new String(toChar.convertAll(dest)); <br>
&nbsp;&nbsp;&nbsp;&nbsp;} <br>
&nbsp;&nbsp;&nbsp;&nbsp;catch (Exception e) { <br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;System.out.println(e); <br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return s; <br>
&nbsp;&nbsp;&nbsp;&nbsp;} <br>
&nbsp;&nbsp;} <br>
<br>
&nbsp;&nbsp;public static String ChineseStringToAscii(String s) { <br>
&nbsp;&nbsp;&nbsp;&nbsp;try { <br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;CharToByteConverter toByte = CharToByteConverter.getConverter(&quot;g <br>
b2312&quot;); <br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;byte[] orig = toByte.convertAll(s.toCharArray()); <br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;char[] dest = new char[orig.length]; <br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;for (int i=0;i&lt;orig.length;i++) <br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;dest[i] = (char)(orig[i] &amp; 0xFF); <br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return new String(dest); <br>
&nbsp;&nbsp;&nbsp;&nbsp;} <br>
&nbsp;&nbsp;&nbsp;&nbsp;catch (Exception e) { <br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;System.out.println(e); <br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return s; <br>
&nbsp;&nbsp;&nbsp;&nbsp;} <br>
&nbsp;&nbsp;} <br>
主程序片断如下: <br>
try{ <br>
Statement stmt; <br>
Class.forName(&quot;com.sybase.jdbc.SybDriver&quot;); <br>
Connection conn =DriverManager.getConnection (&quot;jdbc:sybase:Tds:202.9 <br>
7.228.249:5000/todo&quot;,&quot;sa&quot;,&quot;&quot;);&nbsp;&nbsp;&nbsp;<br>
stmt = conn.createStatement (); <br>
String s=&quot;何海涛&quot;;&nbsp;&nbsp;<br>
s=ChineseStringToAscii(s); <br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;stmt.executeUpdate (&quot;insert into russia values('&quot;+s+&quot;',1,1,'&quot;+s+ <br>
&quot;')&quot;); <br>
}catch(Exception e){ <br>
System.out.println(e); <br>
} <br>
在读数据时用String s=AsciiToChineseString(rs.getString(1)) <br>
-------------------- <br>
因为手头只能对这两种数据库进行测试,所以对别的数据库可能出现的情况不能保 <br>
证.不过我估计基本是上面这两种情况.另外,用JDK1.2有的公司提供的Driver也升 <br>
级了,比如Sybase原来的Driver就不好使.原理就是这样,在实际操作中要靠自己摸 <br>
索了.上面两个方法参考了台湾某BBS的一篇文章. <br>
另外,yzhang不知你要的是什么版本,你可以在jconnect软件安装的目录下找JDBC <br>
 Driver包,可能的格式是zip或jar,把他拷出来就行了.我的就是从PowerJ中拷出 <br>
来的 <br>

  </table>
<p align="center"><script src="../../2.js"></script></a>
</body>
</html>

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -