0

下面是我的代码片段,

for(int i = 0;i < 24;i++) {
Calendar calHourlyObj = new GregorianCalendar(2013,05,05);
calHourlyObj.add(Calendar.HOUR_OF_DAY, i);
java.sql.Date sqldate1 = new java.sql.Date((calHourlyObj.getTime()).getTime());
System.out.println("sqldate1"+sqldate1);
}

这里有一个“calHourlyObj”的日历对象,一个特定的日期范围,为此将日历对象设置为循环中一天中的每个小时。当我将此 calHourlyObj 分配给 java.util.Date 时,我得到带有完整时间戳的日期以所需的格式。但我必须将此日期对象传递给一个存储过程,它只接受 java.sql.Date 格式的日期。如果我将我的 calHourlyObj 分配给 java.sql.Date 那么时间戳就会丢失,并且每次日期都是设置为第一个小时。

我如何获得带有完整时间戳的 java.sql.Date。

或者我试过

java.sql.Timestamp sqldate1 = new java.sql.Timestamp((calHourlyObj.getTime()).getTime());
cstmt.setTimeStamp(1,sqldate1 )

java.sql.Timestamp sqldate1 = new java.sql.Timestamp((calHourlyObj.getTime()).getTime());
cstmt.setObject(1,sqldate1,TYPES.Oracle);

但是这里没有得到任何编译错误。但是我的存储过程没有按预期运行。我怎样才能获得具有完整时间戳的 java.sql.Date 对象?

4

1 回答 1

0

您必须使用TIMESTAMP类型创建列,OracleDATE仅解析为第二个。你真的需要毫秒精度吗?您的 OJDBC 版本是什么?

无论如何,做setTimestamp(...,new Timestamp(System.currentMillis()))是正确的事。

于 2013-08-28T07:20:50.763 回答