Chinaunix首页 | 论坛 | 博客
  • 博客访问: 149742
  • 博文数量: 56
  • 博客积分: 245
  • 博客等级: 二等列兵
  • 技术积分: 520
  • 用 户 组: 普通用户
  • 注册时间: 2012-10-08 14:43
个人简介

慢慢来

文章分类

全部博文(56)

文章存档

2017年(5)

2016年(2)

2015年(6)

2014年(28)

2013年(5)

2012年(10)

我的朋友

分类: 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的问题?)。


转自: http://blog.sina.com.cn/bjfengzi

阅读(2719) | 评论(0) | 转发(1) |
给主人留下些什么吧!~~