java - 在java中以26个字符格式读取db2时间戳?毫秒的最后一个字符丢失

标签 java sql timestamp db2

我正在尝试从数据库表中检索字段。

column name - create_timestamp

Data type of my DB2 column - Timestamp

Format in DB2 - yyyy-MM-dd HH:mm:ss.SSSSSS

我能够在 DB 可视化工具中查看这种格式的数据

我正在使用java从结果集中读取这个值

bean.setCreateTimestamp(rs.getTimestamp(create_timestamp));
bean的

createTimestamp字段是java.sql.Timestamp类型

当我使用 bean.getCreateTimestamp() 打印时,最后三个数字 实际 DB2 值:缺少 2016-01-30 11:43:06.006000 毫秒。

yyyy-MM-dd HH:mm:ss.SSS是打印的格式

系统输出值:来自bean>>2016-01-30 11:43:06.006

我应该怎么做才能获得完整的时间戳? 我需要这些数据来创建用于生成报告的文件名。

最佳答案

你的问题很困惑,不确定你是在Java中还是在数据库中捕获当前时间。无论哪种方式,您都在使用一个麻烦的旧日期时间类 (java.sql.Timestamp),该类现在已被遗留,已被 java.time 类取代。

java.time 类使用纳秒的分辨率,最多支持小数秒的 9 位十进制数字。 在任何版本的 Java 中,您都可以携带纳秒值。但是,捕获当前时刻则是另一回事了。

  • Java 8
    在 Java 8 中捕获当前时刻仅限于毫秒,分辨率为三位数。

  • Java 9 及更高版本
    在 Java 9 中捕获当前时刻使用 fresh implementationjava.time.Clock具有更精细的分辨率,当然取决于主机硬件的限制。

在使用 Oracle Java 9.0.4 的配备 Intel i7 芯片的 MacBook Pro 上运行的 macOS Sierra 上,我以微秒为单位捕获六位小数的当前时刻。

Instant.now()

2018-03-09T21:03:33.831515Z

使用支持 JDBC 4.2 及更高版本的 JDBC 驱动程序,您应该能够直接与数据库交换 java.time 对象。无需再次使用java.sql.Timestamp

如果您的 DB2 列缺少时区或相对于 UTC 的偏移量信息,请使用 Java 中的 LocalDateTime 类。

LocalDateTime ldt = myResultSet.getObject( … , LocalDateTime.class ) ;

如果您的数据库列采用 UTC,请使用 Instant 类。

Instant instant = myResultSet.getObject( … , Instant.class ) ;
<小时/>

关于java.time

java.time框架内置于 Java 8 及更高版本中。这些类取代了麻烦的旧类 legacy日期时间类,例如 java.util.Date , Calendar , & SimpleDateFormat .

Joda-Time项目,现在位于 maintenance mode ,建议迁移到java.time类。

要了解更多信息,请参阅 Oracle Tutorial 。并在 Stack Overflow 上搜索许多示例和解释。规范为JSR 310 .

您可以直接与数据库交换java.time对象。使用JDBC driver符合JDBC 4.2或稍后。不需要字符串,不需要 java.sql.* 类。

从哪里获取java.time类?

ThreeTen-Extra项目通过附加类扩展了 java.time。该项目是 java.time future 可能添加的内容的试验场。您可能会在这里找到一些有用的类,例如 Interval , YearWeek , YearQuarter ,和more .

关于java - 在java中以26个字符格式读取db2时间戳?毫秒的最后一个字符丢失,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41359751/

相关文章:

java - 无法在eclipse中为spring mvc应用程序启动tomcat服务器

java - Android Integer资源可以用在switch语句中吗?

sql - 选择/查询 "into"JSON 数组

php - ODBC更改json数组格式

scala - 如何将时间戳列转换为纪元秒?

javascript - 在 JavaScript 中对时间戳数组进行排序

java - 如何将 ENUM 绑定(bind)到单选按钮?

sql - 创建对两个列组合MSSQL的约束

timestamp - ArangoDB如何申请 'Group by'(收集或...?)

java - 当 pdf 生成失败时,向 portlet 资源响应提供错误页面