jdbc-chinese.htm

来自「写给JSP初级程序员的书」· HTM 代码 · 共 210 行

HTM
210
字号
<html><!-- #BeginTemplate "/Templates/more.dwt" -->
<head>
<!-- #BeginEditable "doctitle" --> 
<title>csdn_JDBC中的中文处理</title>
<!-- #EndEditable -->
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<STYLE type=text/css>
A:link {
	COLOR: #000000; FONT-FAMILY:verdana,宋体,新宋体; TEXT-DECORATION: none
}
A:visited {
	COLOR: #333399; FONT-FAMILY:verdana,宋体,新宋体; TEXT-DECORATION: none
}
A:active {
	COLOR: #ff0000; FONT-FAMILY:verdana,宋体,新宋体; TEXT-DECORATION: none
}
A:hover {
	COLOR: black; TEXT-DECORATION: underline
}
BODY {
	 COLOR: #000000; FONT-SIZE:9pt; LETTER-SPACING: normal; LINE-HEIGHT: 150%; WORD-SPACING: 2em
}
TH {
	FONT-SIZE: 9pt
}
TD {
	FONT-SIZE: 9pt
}
TD.page {
	COLOR: #000000; FONT-SIZE:9pt; LETTER-SPACING: normal; LINE-HEIGHT: 150%; WORD-SPACING: 2em
}
TD.title {
	COLOR: #000000; FONT-FAMILY:verdana,宋体,新宋体
}
TD.detail {
	COLOR: #9966ff; FONT-FAMILY:verdana,宋体,新宋体
}
</STYLE>

</head>

<body bgcolor="#FFFFFF" text="#000000" >
<div align="center"></div>
<table width="700" border="0" align="center">
  <tr> 
    <table width="700" border="1" cellpadding="1" cellspacing="0" bordercolorlight="#9898ba" bordercolordark="#000000">
        
      </table>
      <table width="700" cellspacing="0" cellpadding="0" bgcolor="9898ba" border="0">
        <tr valign="middle"></tr>
      </table>
      <div align="center"><b></div>
      
      <br>
      <table width="700" border="0">
        <tr> 
          <td width="20">&nbsp;</td>
          <td colspan="2"> 
            <div align="center">
              <h3><b><!-- #BeginEditable "5" -->
              <h3><font face="Verdana, Arial, Helvetica, sans-serif" ><b>JDBC中的中文处理</b></font></h3>
              <!-- #EndEditable --></b></h3>
            </div>
          </td>
          <td width="20">&nbsp;</td>
        </tr>
        <tr> 
          <td width="20">&nbsp;</td>
          <td  colspan="2"><!-- #BeginEditable "6" --><br>
            我们在做一个JAVA的应用,不可避免地要处理中文。经过<br>
            艰苦的探索,目前有一些进展,找到了一些解决方法,但仍然<br>
            面临着无法解决的问题。在此作一整理,希望对大家有所帮助,<br>
            同时请各位高手帮忙考虑我们的问题。<br>
            Email: sailor@mailserv.stu.edu.cn
            <p>背景:<br>
              JDK 1.15<br>
              VCafe 2.0<br>
              JPadPro<br>
              SERVER:<br>
              NT IIS<br>
              Sybase System 10 <br>
              JDBC: Jconnect<br>
              CLIENT:<br>
              Browser: Netscape 4.04 + Patch<br>
              PWin95 &amp; Pwin98 Beta3</p>
            <p>CLASS文件存放在 SERVER,由BROWSER 运行APPLET,APPLET只<br>
              起调入FRAME类主程序的作用。界面包括Text field, Text Area,<br>
              List, Choice 等。</p>
            <p>一,取中文<br>
              用JDBC执行SELECT语句从SERVER取数据(中文)后,将数据<br>
              用APPEND方法加到TEXT AREA(TA),不能正确显示。但加到<br>
              LIST中时,则大部分汉字可正确显示。</p>
            <p>处理:将数据按“ISO-8859-1”格式转为字节数组,再按系统<br>
              缺省编码格式(default character encoding)转为STRING,即可在TA和LIST中正确显示。<br>
              程序段如下:</p>
            <p>dbstr2 = results.getString(1);<br>
              //*********************************************************************<br>
              // After read result from Database server, Convert the result string.</p>
            <p>dbbyte1 = dbstr2.getBytes(&quot;iso-8859-1&quot;);<br>
              dbstr1 = new String(dbbyte1);<br>
              //*********************************************************************</p>
            <p>二,写中文到DB<br>
              处理方式与以上相逆,先将SQL语句按DEFAULT CHARACTER ENCODING<br>
              转为字节数组,再按ISO-8859-1转为STRING,然后送执行,<br>
              则中文信息可正确写入DB。</p>
            <p>sqlstmt = tf_input.getText();</p>
            <p>//***************************************************************************** 
              <br>
              // Before send statement to Database server, Convert sql statement.</p>
            <p>dbbyte1 = sqlstmt.getBytes();<br>
              sqlstmt = new String(dbbyte1,&quot;iso-8859-1&quot;);<br>
              //***************************************************************************** 
            </p>
            <p>_stmt = _con.createStatement();<br>
              _stmt.executeUpdate(sqlstmt);<br>
              。。。。。。</p>
            <p>问题:<br>
              以上方法当本地客户机上存在CLASSPATH指向JDK的CLASSES。ZIP<br>
              时(称为A情况),可正确运行。<br>
              但如果客户机只有Browser,没有JDK和CLASSPATH时<br>
              (称为B情况),则汉字无法正确转换。</p>
            <p>我们的分析:<br>
              1,<br>
              经过测试,在A情况下,程序运行时系统的default character<br>
              encoding = &quot;GBK&quot; or &quot;GB2312&quot;.<br>
              在B情况下,程序启动时,Browser 的JAVA CONSOLE中出现<br>
              如下信息:<br>
              can't find resource for <br>
              sun.awt.windows.awtLocalization_zh_CN<br>
              然后系统的<br>
              default characterencoding = &quot;8859-1&quot;.</p>
            <p>2,<br>
              如果在转换字符串时不采用default character encoding,<br>
              而是直接采用“GBK”或“GB2312”,则在A情况下仍然可正常,<br>
              在B情况下,系统出现错误:UnsupportedEncodingException。</p>
            <p>3,<br>
              在本地客户机上,我把JDK的CLASSES。ZIP解压后,放在另一个<br>
              目录中,CLASSPATH只包含该目录。然后逐步删除目录中的CLASS<br>
              文件,一边运行测试程序,最后发现在一千多个CLASS文件中,<br>
              只有一个是不可缺少的,该文件是:<br>
              sun.io.CharToByteDoubleByte.class<br>
              我将该文件拷到SERVER端和其它的类放在一起,并在程序的开头<br>
              IMPORT它,仍然在B情况下无法正常。</p>
            <p>4,<br>
              在A情况下,如果在CLASSPTH中去掉<br>
              sun.io.CharToByteDoubleByte.class,则程序运行时,<br>
              测得default character encoding为“8859-1”,否则为<br>
              GBK 或GB2312。</p>
            <p>5,<br>
              分析BROWSER程序NETSCAPE目录下的文件<br>
              /program/java/classes/java40.jar, 发现其中没有包括<br>
              sun.io.CharToByteDoubleByte.class,<br>
              不知这是需要升级,还是有其它方法可以解决? 盼望各位高手指导!Email: sailor@mailserv.stu.edu.cn</p>
            <p>--<br>
              ※ 来源:·BBS 水木清华站 bbs.net.tsinghua.edu.cn·[FROM: DHCP159_158.STU] 
              <br>
              发信人: barebell (小心), 信区: Java<br>
              标 题: Re: ● ● JDBC中文处理:方法与问题<br>
              发信站: BBS 水木清华站 (Tue May 19 22:38:19 1998) WWW-POST</p>
            <p>现在我们取得的一点小小进展,在转换字符串时不采用default character <br>
              encoding,而是直接采用“GBK”或“GB2312”,在情况A和B底下,从DB取数据<br>
              都没有问题,但是写中文到DB也采用“GBK”或“GB2312”时,情况B仍是出错的。</p>
            <p>发信人: mah (chip), 信区: Java<br>
              标 题: 通过jdbc driver获取数据库中文信息揭密<br>
              发信站: BBS 水木清华站 (Tue Aug 11 20:42:16 1998) WWW-POST</p>
            <p>当我们使用老外公司开发的jdbc第四类driver获取数据库中文信息时,常会出现乱码现象<br>
              ,如????D.<br>
              解决办法1:<br>
              使用interface ResultSet的方法getBytes()得到一byte[],然后由此byte[]数组产生一<br>
              新的<br>
              String,可获得正确的汉字,但此方法有一定的局限性,在某些driver上可以实现,如<br>
              weblogic公司<br>
              开发的fastforward产品。另此种方法不规范,根据sun jdbc的标准varchar和var推荐用<br>
              getString()<br>
              方法来获取。<br>
              解决办法2:<br>
              使用interface ResultSet的方法getString(),这时我们得到的String一定是乱码,如何<br>
              解决,<br>
              String temp = result.getString (s);<br>
              if (temp != null) {<br>
              byte[] b = temp.getBytes (&quot;8859_1&quot;);<br>
              temp = new String (b);<br>
              此时的temp一定是正确的中文,,,,,,此种方法我在sybase公司开发的jconnect4上<br>
              实验成功,在fastforward<br>
              上也成功。</p>
            <p></p>
            <!-- #EndEditable --></td>
          <td width="20">&nbsp;</td>
        </tr>
        <tr> 
          <td width="20" height="11">&nbsp;</td>
          <td width="541" height="11"><!-- #BeginEditable "7" --><!-- #EndEditable --></td>
          <td width="101" height="11"> 
            
          </td>
          <td width="20" height="11">&nbsp;</td>
        </tr>
      </table><div align="center"> <br>
      </div>
      
    </td>
  </tr>
</table>
<div align="center"> 
  
  <br>
</div>
</body>
<!-- #EndTemplate --></html>

⌨️ 快捷键说明

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