[ZT]Sybase中convert函數(shù)中第三個(gè)參數(shù)的格式

[66] HGCDB1.dmo_govcorp.1> select CONVERT(VARCHAR(24),GETDATE(),109)
[66] HGCDB1.dmo_govcorp.2> go

 ------------------------
 Oct 14 2012 11:03:47:833

(1 row affected)

Sybase中convert函數(shù)中第三個(gè)參數(shù)的格式2007年05月07日 星期一 下午 09:07關(guān)于convert函數(shù)
如果是將時(shí)間轉(zhuǎn)換為字符的:
0 (mon dd yyyy hh:miAM/PM)
1 (mm/dd/yy)
2 (yy.mm.dd)
3 (dd/mm/yy)
4 (dd.mm.yy)
5 (dd-mm-yy)
6 (dd mon yy)
7 (mon dd,yy)
8 (hh:mm:ss)
9 (mon dd,yyyy hh:mi:ss:mmmAM/PM)
10 (mm-dd-yy)
11 (yy/mm/dd)
12 (yymmdd)
還有100、101、102...和上面的對(duì)應(yīng),只不過將yy變?yōu)閥yyy.
sybase里面的時(shí)間存儲(chǔ)。
對(duì)于java.sql.date而言,里面存儲(chǔ)了精確到毫秒的時(shí)間。
但是我們用java.sql.PrepareStatement.setDate(java.sql.date)往數(shù)據(jù)庫寫入時(shí)間的時(shí)候,只能寫入年月日值,其它都被忽略掉了。

所以應(yīng)該用sql函數(shù)convert寫入完整的時(shí)間值
insert into tablename (columnname) values ( Convert(datetime,'?',109))
其中'?'是和第三個(gè)參數(shù)對(duì)應(yīng)的時(shí)間字符串。
convert第三個(gè)參數(shù)的含義是
101 美國(guó) mm/dd/yyyy
102 ANSI yy.mm.dd
103 英國(guó)/法國(guó) dd/mm/yy
104 德國(guó) dd.mm.yy
105 意大利 dd-mm-yy
106 - dd mon yy
107 - mon dd, yy
108 - hh:mm:ss
109 () 默認(rèn)值 + 毫秒 mon dd yyyy hh:mi:ss:mmmAM(或 PM)
110 美國(guó) mm-dd-yy
111 日本 yy/mm/dd
112 ISO yymmdd
113 (
) 歐洲默認(rèn)值 + 毫秒 dd mon yyyy hh:mm:ss:mmm(24h)
114 - hh:mi:ss:mmm(24h)
120 () ODBC 規(guī)范 yyyy-mm-dd hh:mm:ss[.fff]
121 (
) ODBC 規(guī)范(帶毫秒) yyyy-mm-dd hh:mm:ss[.fff]
126(*) ISO8601 yyyy-mm-dd Thh:mm:ss:mmm(不含空格)
130
科威特 dd mon yyyy hh:mi:ss:mmmAM
131
科威特 dd/mm/yy hh:mi:ss:mmmAM
注意不同版本的sybase對(duì)第三個(gè)參數(shù)的支持不一樣。
一般來說,109都是支持的。
附錄java里面的時(shí)間格式轉(zhuǎn)換函數(shù)(for 109)

public static String formatDateForSybase(java.util.Date date) {
  if (date == null) {   return "";}
  String pattern="MMM dd yyyy hh:mm:ss:SSSa";
  SimpleDateFormat sdf = new SimpleDateFormat(pattern,Locale.ENGLISH);
  String strDate=sdf.format(date);
  return strDate;
}

sybase里面的讀取
當(dāng)把sybase的datetime對(duì)象讀到j(luò)ava.sql.ResultSet對(duì)象里面時(shí),如果使用ResultSet的getDate()只能夠得到日期,而getTime()方法只能得到當(dāng)天的時(shí)間(注意這里居然還會(huì)有8小時(shí)的時(shí)差,我不知道為什么,是數(shù)據(jù)庫服務(wù)器放在美國(guó)的緣故?---沒有道理)。所以應(yīng)該使用getTimestamp()方法,它可以得到精確到毫秒的完整時(shí)間。
附錄得到時(shí)間的函數(shù)

public static java.util.Date 
getSybaseDate(ResultSet rs, String columnName) throws SQLException{
  Timestamp ts=rs.getTimestamp(columnName); 
  Calendar dest = Calendar.getInstance();
  long c=ts.getTime();
  dest.setTimeInMillis(c);
  return dest.getTime();
}

另外,這里得到的時(shí)間和存入的時(shí)間會(huì)有個(gè)正負(fù)2毫秒內(nèi)的誤差。(我也不知道為什么,難道是sybase的問題?)。

轉(zhuǎn)自: http://blog.sina.com.cn/bjfengzi

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容