慢慢来
分类: Sybase
2012-10-11 16:31:06
[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函数中第三个参数的格式
2007年05月07日 星期一 下午 09:07
关于convert函数
如果是将时间转换为字符的:
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...和上面的对应,只不过将yy变为yyyy.
sybase里面的时间存储。
对于java.sql.date而言,里面存储了精确到毫秒的时间。
但是我们用java.sql.PrepareStatement.setDate(java.sql.date)往数据库写入时间的时候,只能写入年月日值,其它都被忽略掉了。
所以应该用sql函数convert写入完整的时间值
insert into tablename (columnname) values ( Convert(datetime,'?',109))
其中'?'是和第三个参数对应的时间字符串。
convert第三个参数的含义是
101 美国
mm/dd/yyyy
102 ANSI
yy.mm.dd
103 英国/法国
dd/mm/yy
104 德国
dd.mm.yy
105 意大利
dd-mm-yy
106 - dd
mon yy
107 -
mon dd, yy
108
- hh:mm:ss
109
(*) 默认值 + 毫秒
mon dd yyyy hh:mi:ss:mmmAM(或
PM)
110 美国
mm-dd-yy
111 日本
yy/mm/dd
112 ISO
yymmdd
113 (*)
欧洲默认值 + 毫秒 dd mon
yyyy hh:mm:ss:mmm(24h)
114
- hh:mi:ss:mmm(24h)
120
(*) ODBC 规范
yyyy-mm-dd hh:mm:ss[.fff]
121
(*) ODBC 规范(带毫秒)
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对第三个参数的支持不一样。
一般来说,109都是支持的。
附录java里面的时间格式转换函数(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里面的读取
当把sybase的datetime对象读到java.sql.ResultSet对象里面时,如果使用ResultSet的getDate()只能够得到日期,而getTime()方法只能得到当天的时间(注意这里居然还会有8小时的时差,我不知道为什么,是数据库服务器放在美国的缘故?---没有道理)。所以应该使用getTimestamp()方法,它可以得到精确到毫秒的完整时间。
附录得到时间的函数
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();
}
另外,这里得到的时间和存入的时间会有个正负2毫秒内的误差。(我也不知道为什么,难道是sybase的问题?)。