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


    问题

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

    详细问题

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

    java.sql.Date
    
    • 1

    或是

    java.util.Date
    
    • 1

    或是

    java.time.LocalDate
    
    • 1

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

    解决方案

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

    java.sql.Timestamp
    
    • 1

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

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

    涉及相关包

    import com.fasterxml.jackson.annotation.JsonFormat;
    
    • 1

    涉及依赖

    <dependency>
        <groupId>com.fasterxml.jackson.coregroupId>
        <artifactId>jackson-databindartifactId>
    dependency>
    
    • 1
    • 2
    • 3
    • 4

    产生原因

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

    解决原因

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

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

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

    参考文献

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

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

  • 相关阅读:
    【Linux】基础IO ——中
    使用RestCloud ETL Shell组件实现定时调度DataX离线任务
    动态规划问题(一)
    编程题:寻找无限循环小数的循环节及长度
    20年上海站D题Walker(二分,简洁)
    阿拉伯糖偶联核苷酸,UDP-b-L-arabinopyranose disodium salt,UDP-β-L-Ara.2Na
    npm版本升级报错
    vue3 中的ref、reactive的介绍
    计算机网络概念入门(十一)
    SpringBoot笔记:SpringBoot集成MyBatis实战
  • 原文地址:https://blog.csdn.net/T_Y_F_/article/details/136599722