【问题标题】:Value from MySQL TIME to Java Date not translating correctly从 MySQL TIME 到 Java Date 的值未正确转换
【发布时间】:2019-09-20 18:38:31
【问题描述】:

在我的 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)。这种行为是否有原因,以及纠正此问题的方法?

【问题讨论】:

  • 您的应用程序和您的 MySQL 数据库在不同的时区运行。柱子的类型是什么? DATETIMETIMESTAMP?
  • 列的数据类型是TIME
  • 您的应用在哪个时区运行?您的数据库在哪个时区?
  • 我想你应该考虑 -5 小时的时差(时区)而不是 +19 小时。
  • 根据经验,我总是将数据库时区保持为 UTC,然后在应用程序上显示时转换为本地时间

标签: java mysql spring-boot jpa


【解决方案1】:

发生的情况是日期以 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,只是举个例子以防您感兴趣。

【讨论】:

    猜你喜欢
    • 2021-01-20
    • 2017-11-30
    • 2021-09-27
    • 2020-05-08
    • 2018-04-04
    • 2014-11-24
    • 2020-02-11
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多