java - 为什么当日期在 1970-01-01 之后时 java.sql.Timestamp 返回负值

标签 java timestamp sql-timestamp

Timestamp timestamp = Timestamp.valueOf("1970-01-01 01:00:00");
System.out.println(timestamp.getTime());

知道这段代码返回 -25200000 吗? 我认为 1970-01-01 00:00:00 之后的时间将为正。

最佳答案

您正在使用一个糟糕的日期时间类,该类多年前已被 JSR 310 中定义的现代 java.time 类取代。切勿使用 java.sql.Timestamp .

将您的输入解析为 LocalDateTime,因为它缺少时区或与 UTC 的偏移量指示符。将中间的空格替换为 T 以符合日期时间格式的 ISO 8601 标准。

String input = "1970-01-01 01:00:00".replace( " " , "T" ) ;
LocalDateTime ldt = LocalDateTime.parse( input ) ;

显然您的意思是代表 UTC 中的某个时刻。应用偏移量来获取 OffsetDateTime

OffsetDateTime odt = ldt.atOffset( ZoneOffset.UTC ) ;

获取自 UTC 1970 年第一个时刻的纪元引用以来的毫秒数。

long millis = odt.toInstant().toEpochMilli() ;

3600000

关于java - 为什么当日期在 1970-01-01 之后时 java.sql.Timestamp 返回负值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61341120/

相关文章:

java - JDBC 将日期转换为 UTC

postgresql - 如何在具有 select 语句的 pgsql 函数中引用时间戳变量

java - GSON自定义解析

java - 使用进度回调将文件或 InputStream 上传到 S3

java - 在 main 中调用带有引用变量的方法

java - 如何在 jenkinsfile 中将参数传递给 sbt

java - 如何在java中生成满足泊松分布的随机时间戳

javascript - 是否可以修改浏览器的 Date 对象?

sql - 删除 Postgresql 中的冗余时间戳范围