gpt4 book ai didi

java - Postgresql 日期类型和 java SimpleDateFormat

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

我有一个日期类型的数据库列,其值如下

2014-05-01

然后我有以下 hibernate 映射:

@Temporal(TemporalType.DATE)
@Column(name = "end_date", nullable = false, length = 13)
public Date getEndDate() {
return this.endDate;
}

public void setEndDate(Date endDate) {
this.endDate = endDate;
}

当我以下列方式在 JSF 页面中引用此日期时

<h:outputText value="#{someBean.endDate}">
<f:convertDateTime pattern="d MMM yyyy" />
</h:outputText>

它读作

'30 Apr 2014'

所以我删除了 f:convertDateTime,它显示:

'5/1/2014'

然后我将 f:convertDateTime 更改为:

<h:outputText value="#{someBean.endDate}">
<f:convertDateTime pattern="HH:mm d MMM yyyy" />
</h:outputText>

上面写着:

'23:00 30 Apr 2014'

所以我的猜测是我的计算机设置为 BST(英国夏令时)并且数据库中的日期以某种方式设置为 GMT(或祖鲁时间),因此 -1 小时会导致日期向后移动到前一天?

有什么办法可以阻止这种情况发生吗,我只想把它当作一个日期,没有时间成分!

最佳答案

您还应该指定时区(以及为了安全起见的英语语言环境):

<h:outputText value="#{someBean.endDate}">
<f:convertDateTime pattern="d MMM yyyy" timeZone="GMT" locale="en" />
</h:outputText>

在此我假设输入是在 UTC 时区(即文字日期最初是相对于 UTC 存储的),因此使用相同的输出格式偏移量不会更改日期(以及您的中间输出“5/1/2014"只是默认的美国格式被相同的偏移效果改变了)。

如果您使用其他时区转换存储日期,则必须调整时区属性(例如“欧洲/伦敦”)。

更新:我找到了这个 SO-question这也应该对您有所帮助。

关于java - Postgresql 日期类型和 java SimpleDateFormat,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22868648/

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