如何获取具有完整时间戳的java.sql.Date对象

如何获取具有完整时间戳的java.sql.Date对象,java,sql,sql-server,date,Java,Sql,Sql Server,Date,下面是我的代码片段 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("sqldate

下面是我的代码片段

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


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

您必须使用
时间戳
类型创建列,并且Oracle
日期
仅解析为第二个。你真的需要毫秒精度吗?你的OJDBC版本是什么


无论如何,执行
setTimestamp(…,newtimestamp(System.currentMillis())
是正确的做法。

java.sql.Date
没有时间组件。第一个
java.sql.Timestamp
snippet到底出了什么问题?问题是我的存储过程正在拾取Timestamp对象,但在获取它之后并没有填充任何记录
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);