gpt4 book ai didi

java - JPA java.util.Date 问题

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

我的数据库中有日期字段,其值为“27-AUG-10 15:30:00”。我正在使用 JPA 检索并设置到模型对象中。在模型对象中,日期是额外的一天“2010-08-28 04:00:00.0”。检索时,日期应该是 2010 年 8 月 27 日,但实际日期是 2010 年 8 月 28 日。您能否建议我为什么要检索额外一天。

 import java.util.Date;
import javax.persistence.Column;
public class Model
{
@Column(name = "BEGIN_DATE")
private Date startDate;

public Date getStartDate() {
return startDate;
}

public void setStartDate(Date startDate) {
this.startDate = startDate;
}

}

最佳答案

默认情况下,数据库将存储您所在的时区。但是,在检索日期时,它不会添加回您所在的时区。该日期显示为 GMT。看看使用 JodaTime 来获得更好的日期库。

我给你举个例子。您需要 JodaTime 库和 JadiraTypes 库来通过 Hibernate 保留 JodaTime 日期。

http://mvnrepository.com/artifact/joda-time/joda-time/2.3
http://mvnrepository.com/artifact/org.jadira.usertype/usertype.jodatime/2.0.1

您的代码将如下所示:

@Type(type="org.jadira.usertype.dateandtime.joda.PersistentLocalDateTime")
私有(private) LocalDateTime 日期;

这将为您保留 Hibernate 的日期。

我 90% 确定 JodaTime 支持为您添加回时区。如果您真的担心,请将它们作为时间戳存储在数据库中。

尝试如上所述更改为 JodaTime,如果有任何问题请告诉我。

关于java - JPA java.util.Date 问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22294744/

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