作者:korn 來源:賽迪網
讓我們看一個編碼的JAVA代碼:
//ECov.java
import java.io.UnsupportedEncodingException;
public class ECov
{
public static String asc2gb(String asc){
String ret;
if(asc==null)return asc;
try{
ret=new String(asc.getBytes("ISO8859_1"),"GB2312");
}
catch(UnsupportedEncodingException e){
ret=asc;
}
return ret;
}
public static String gb2asc(String gb){
String ret;
if(gb==null)return gb;
try{
ret=new String(gb.getBytes("GB2312"),"ISO8859_1");
}
catch(UnsupportedEncodingException e){
ret=gb;
}
return ret;
}
public static int byte2int(byte b){
return ((-1)>>>24)&b;
}
}
其實這段代碼的意思也就是把兩種方法合而為一了。
在進行數據庫插入時要用ECov.gb2asc(arg),要在讀時要用ECov.asc2gb(arg)。其中最關鍵的一點就是Oracle好像只認識ISO8859_1這種格式的編碼吧(僅是我的想法)。
三、一些小細節
?。?、就是setAutoCommit(true or false),就是我們在sqlPlus中常用commit()的功能,如果是用true,就不要用commit(),否則還是用commit()方法的。
?。?、對日期類型的處理,其實他并不是想象中setDate(),getDate()那么簡單的,中間有很大的漏洞。大家自己多調試就會覺得有很多的樂趣的。
?。?、在和數據庫中最好是采用連接池技術,用標準的J2EE的環境,用簡單的JNDI技術,是很好的一種方法的。
原文轉自:http://www.anti-gravitydesign.com