gpt4 book ai didi

java - 从 MySQL TIME 到 Java Date 的值未正确转换

转载 作者:行者123 更新时间:2023-11-29 15:37:58 26 4
gpt4 key购买 nike

在我的 MySQL 数据库中,我有一个包含三列的表,如下所示

id | name | notification_time
-----------------
1 | name1 | 00:30:00
2 | name2 | 01:30:00
3 | name3 | 01:00:00

notification_time 是 TIME 的数据类型。

在我的 Spring-boot 应用程序中,对我的表进行建模

@Entity
@Table(name = "table")
public class TableEntity implements Serializable {

@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "id")
private Integer id;

@Column(name = "name")
private String name;

@Column(name = "notification_time")
@Temporal(TemporalType.TIME)
private Date notificationTime;

要检索值,我只需通过我的存储库检索所有条目

tableRepository.findAll();

当我从数据库检索 notification_time 时,我看到的每个值是

19:30:00
20:30:00
20:00:00

所以它似乎是从我的表中的值中抵消时间,但 19 小时?我想保留表中的值(即 00:30:00、01:30:00、01:00:00)。这种行为有原因吗?有纠正方法吗?

最佳答案

发生的情况是日期以 UTC 形式存储到 MSSQL 中。这通常是可取的,因为当从多个区域运行应用程序实例时,您不希望看到三个晚上 7 点。如果 LocalDateTime 在一个时区为下午 6 点,在另一个时区为下午 7 点,在另一个时区为晚上 8 点,则数据库中的时间。如果您有理由更喜欢查看本地时间,那么您可以在 Java 中指定一个区域,从时间字段中减去本地时间和 UTC 时间之间的小时差,或者在需要执行 SELECT 查询时转换数据库中的数据.

假设您知道您的本地时区是美国东部,您可以在 Java 中执行以下操作:

timeNow.setHours(LocalDateTime.now().getHours() - ChronoUnit.HOURS.between(LocalDateTime.now(), LocalDateTime.now(ZoneOffset.UTC)));

或者 SQL 中类似的东西:

SELECT CONVERT(TIME, a_time AT TIME ZONE 'US Eastern Standard Time') FROM    
schema.your_table;

我肯定会避免使用 Java impl,只是给出一个示例,以防您感兴趣。

关于java - 从 MySQL TIME 到 Java Date 的值未正确转换,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58033660/

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