从MySQL TIME到Java Date的值无法正确翻译

时间:2019-09-20 18:38:31

标签: java mysql spring-boot jpa

在我的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)。有这种现象的原因,并且有一种纠正方法吗?

1 个答案:

答案 0 :(得分:0)

正在发生的事情是日期以UTC格式存储到MSSQL。通常这是理想的,因为从多个区域运行应用程序实例时,您不想看到下午三点。如果LocalDateTime在一个时区中是6pm,在另一个时区中是7pm,在另一个时区中是晚上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,只是举个例子,以防您感兴趣。