Sybase 的convert函数

本文探讨了SQL中日期时间的表示方式与Java的日期时间转换,特别关注了使用convert函数进行日期时间转换以实现完整时间存储的方法。同时介绍了如何在Java中正确处理并存储SQL日期时间数据,包括使用getTimestamp()方法获取精确到毫秒的完整时间。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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();
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值