gpt4 book ai didi

java - 如何将时间戳字符串转换为另一个时区的时间戳

转载 作者:行者123 更新时间:2023-12-01 19:47:41 25 4
gpt4 key购买 nike

我有一个 UTC 时间戳字符串

val x = "2018-09-26T15:05:19.1121042Z"

我想要一个像这样的函数将其转换为 CST 时区的时间戳对象。

def StringToTimeStamp(str: String): Timestamp = {
val timeFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss")
val timeZone = TimeZone.getTimeZone("America/Chicago")
timeFormat.setTimeZone(timeZone);
val now = timeFormat.format(str)
val ts = java.sql.Timestamp.valueOf(now)
ts
}

但是,我不知道SimpleDateFormat我的字符串的格式,因为我无法输入像 T/Z 这样的字母,因为它们出现在我的字符串中 x 。我将如何实现这个目标?

最佳答案

祖鲁时间

输入字符串末尾的 Z 表示 UTC ,发音为“祖鲁”。

ISO 8601

您的输入字符串符合标准 ISO 8601格式。 java.time 类在解析或生成字符串时默认使用这些标准格式。

即时

将您的字符串解析为 Instant 。 Instant 表示 UTC 中的一个时刻,分辨率为纳秒。

Instant instant = Instant.parse("2018-09-26T15:05:19.1121042Z") ;

您的 JDBC 驱动程序也许能够即时

myPreparedStatement.setObject( … , instant ) ;

偏移日期时间

如果没有,您的 JDBC 4.2 或更高版本的驱动程序需要接受 OffsetDateTime .

OffsetDateTime odt = instant.atOffset( ZoneOffset.UTC ) ;
myPreparedStatement.setObject( … , odt ) ;

避免java.sql.Timestamp

如果您有较旧的JDBC driver之前JDBC 4.2 ,然后转而使用可怕的 java.sql.Timestamp。但是只有在绝对必要的情况下才使用这些遗留的日期时间类,因为它们是一团糟。

您可以通过调用添加到旧类中的新转换方法来在现代类和遗留类之间进行转换。

java.sql.Timestamp ts = java.sql.Timestamp.from( instant ) ;

…还有…

Instant instant = ts.toInstant() ;

时区

大概您询问的是java.sql.Timestamp,因为您正在与数据库交换值。

您的time zone of Chicago与数据库工作无关,因为大多数数据库都以 UTC 形式存储时刻。

ZonedDateTime

但为了向用户展示,您可能需要从 UTC 调整为时区。

ZoneId z = ZoneId.of( "America/Chicago" ) ;
ZonedDateTime zdt = instant.atZone( z ) ;

生成本地化格式的字符串

DateTimeFormatter f = DateTimeFormatter.ofLocalizedDateTime( FormatStyle.FULL ).withLocale( Locale.US ) ;
String output = zdt.format( f ) ;

关于java - 如何将时间戳字符串转换为另一个时区的时间戳,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52521122/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com