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

Posted

技术标签:

【中文标题】如何获取具有完整时间时间戳的 java.sql.Date 对象【英文标题】:How to get java.sql.Date Object with full time timestamp 【发布时间】:2013-08-31 03:34:48 【问题描述】:

下面是我的代码sn-p,

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 对象?

【问题讨论】:

java.sql.Date 没有时间组件。第一个java.sql.Timestampsn-p到底有什么问题? 问题是我的存储过程正在选择时间戳对象,但是在获取它之后没有填充任何记录 【参考方案1】:

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

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

【讨论】:

以上是关于如何获取具有完整时间时间戳的 java.sql.Date 对象的主要内容,如果未能解决你的问题,请参考以下文章

如何选择每个项目具有最大时间戳的行集?

SQL查询以获取具有不同时间戳的多行

Redshift 获取具有最高优先级和时间戳的行

通过 linq 对实体查询进行分组,以通过加入表来获取具有最新时间戳的一条记录

CouchDB 查询以获取具有 MAX 时间戳的文档

如何选择具有当天时间戳的行?