CriteriaBuilder Instant to postgres TIMESTAMP conversion



我有一个Postrges DB表,它有一个列created_at TIMESTAMP WITHOUT TIMEZONE。 在此表中,有一条时间戳2020-02-15 00:00:00的记录。 在休眠实体中,此字段映射如下:

@Column(name = "created_at", updatable = false)
@CreationTimestamp
private Instant createdAt;

我正在尝试使用CriteriaAPI查询记录。我以这种方式形成查询:

criteriaBuilder.greaterThanOrEqualTo(rootEntity.get("created_at"), Instant.ofEpochSecond(1581724800L).truncatedTo(ChronoUnit.DAYS))

数字1581724800L对应于2020-02-15 00:00:00,所以它应该可以工作。但是,此查询不会返回我要查找的记录。 查看数据库日志,我发现实际上它查询时间戳2020-02-15 03:00:00。因此,即使我使用的是Instant并且查询中TIMESTAMP WITHOUT TIMEZONE了 DB 字段,它也会将时间戳转换为分区时间戳。

可能是什么问题,我在这里做错了什么?

看起来休眠以某种方式改变了时间并转移到不同的时区。也许尝试将其设置为 UTCspring.jpa.properties.hibernate.jdbc.time_zone = UTC或尝试设置不同的时区,看看查询中的时间是否也会更改

最新更新