【发布时间】: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 数据库在不同的时区运行。柱子的类型是什么?
DATETIME或TIMESTAMP? -
列的数据类型是
TIME -
您的应用在哪个时区运行?您的数据库在哪个时区?
-
我想你应该考虑 -5 小时的时差(时区)而不是 +19 小时。
-
根据经验,我总是将数据库时区保持为 UTC,然后在应用程序上显示时转换为本地时间
标签: java mysql spring-boot jpa