我有一个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
或尝试设置不同的时区,看看查询中的时间是否也会更改