传递datetime数据类型至前端 时分秒消失

文章讲述了在Java中,将数据库的datetime类型转换到前端时,时分秒可能丢失的问题。通过将数据库时间类型改为timestamp,使用java.sql.Timestamp,并利用Jackson的@JsonFormat注解指定日期时间格式,可以保留完整时间信息并适应前端显示需求。
摘要由CSDN通过智能技术生成

问题

传递datetime数据类型至前端 时分秒消失

详细问题

笔者数据库时间类型为datetime,Java实体类无论设置为

java.sql.Date

或是

java.util.Date

或是

java.time.LocalDate

在将时间数据传递给Web前端,时分秒数据都会丢失

解决方案

数据库时间类型设计为timestamp,实体类设计为

java.sql.Timestamp

此时时间的时分秒以及毫秒数据都不会丢失,显示数据为2024-03-09T00.000+00.00
若期望数据格式为
2024-03-09 00:00:00
可添加注解

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

涉及相关包

import com.fasterxml.jackson.annotation.JsonFormat;

涉及依赖

<dependency>
    <groupId>com.fasterxml.jackson.core</groupId>
    <artifactId>jackson-databind</artifactId>
</dependency>

产生原因

如果在将datetime类型的数据传递给前端时丢失了时分秒信息,可能是由于数据在传输过程中的格式化或处理造成的。

解决原因

为了解决时分秒数据丢失的问题,您需要将数据库中的时间类型设计为timestamp,并在Java实体类中使用java.sql.Timestamp。使用timestamp数据类型可以保存时分秒以及毫秒信息,确保数据的完整性。

当您将timestamp类型的时间数据传递给前端时,您可以使用@JsonFormat注解来指定日期时间的显示格式,例如yyyy-MM-dd HH:mm:ss。这样可以确保前端正确显示日期时间数据,并避免丢失时分秒信息。

总结来说,将数据库时间类型设计为timestamp,并在Java实体类中使用java.sql.Timestamp,可以保留完整的日期时间信息,同时通过@JsonFormat注解来指定日期时间的显示格式,以满足前端显示需求。

参考文献

产生原因与解释原因部分 部分内容参考chatgpt

原创不易
转载请标明出处
如果对你有所帮助 别忘啦点赞支持哈
请添加图片描述

  • 8
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

飞滕人生TYF

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值