问题
传递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
原创不易
转载请标明出处
如果对你有所帮助 别忘啦点赞支持哈