1> select convert(varchar(24),getdate(),109)
2> go
------------------------
Jul 24 2015 4:54:38:936
(1 row affected)
1> select convert(varchar(24),getdate(),108)
2> go
------------------------
05:15:09
(1 row affected)
1> select convert(varchar(24),getdate(),113)
2> go
------------------------
2015/24/07
(1 row affected)
1> select convert(varchar(24),getdate(),110)
2> go------------------------
07-24-2015
(1 row affected)
1> select convert(varchar(24),getdate(),101)
2> go
------------------------
07/24/2015
(1 row affected)
1> select convert(varchar(24),getdate(),102)
2> go
------------------------
2015.07.24
(1 row affected)
1> select convert(varchar(24),getdate(),103)
2> go
------------------------
24/07/2015
(1 row affected)
1> select convert(varchar(24),getdate(),104)
2> go
------------------------
24.07.2015
(1 row affected)
1> select convert(varchar(24),getdate(),105)
2> go
------------------------
24-07-2015
(1 row affected)
1> select convert(varchar(24),getdate(),106)
2> go
------------------------
24 Jul 2015
(1 row affected)
1> select convert(varchar(24),getdate(),107)
2> go
------------------------
Jul 24, 2015
(1 row affected)
1> select convert(varchar(24),getdate(),111)
2> go
------------------------
2015/07/24
(1 row affected)
1>
但是我们用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()方法只能得到当天的时间(。所以应该使用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();
}