数据库日期和前端返回的值相差12个小时解决办法

本文详细解析了数据库时间与前端展示时间存在12小时差异的原因,主要由于JSON日期格式化设置不当导致。通过调整@JsonFormat配置,采用yyyy-MM-dd HH:mm:ss和时区GMT+8,成功解决了时间显示不一致的问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

解决数据库中日期跟前端查询出来的日期存在时差的问题

如图数据库中的时间如下


但是基于swagger查询出来的数据的reply_Time是:

相差了12个小时,原因是因为定义的接收的model中转换了日期格式

将转换格式修改为

@JsonFormat(
        pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8"
    )

可以成功的解决时间相差12个小时的问题,这其实是一个时间格式化的问题:

hh:mm:ss  

按照12小时制的格式进行字符串格式化

如果时间处于00:00:00——12:59:59,则返回的字符串正常

如果时间处于13:00:00——23:59:59,则返回的字符串是实际时间-12小时后的值,也就是说比真实的时间少了12个小时。

例如:14:00:00进行格式化后的字符串为“2:00:00”

 

HH:mm:ss

按照24小时制的格式进行字符串格式化

当时间为任意一个区间,则返回的字符串都是正常的。

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值