IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> 关于springboot项目中及mysql中Date、datetime、timestamp类型的相关说明 -> 正文阅读

[Java知识库]关于springboot项目中及mysql中Date、datetime、timestamp类型的相关说明

〇、问题背景

自古以来,我们的springboot项目中常有这样的不一致问题:

  1. 数据库的默认字段,create_time、update_time等字段,使用什么数据类型?(datetime,date,还是timestamp)
  2. 数据库的其他业务字段,用来表示时间的,用什么数据类型?(同上的困惑)
  3. 使用了这些类型后,java代码中的DO、BO要用什么数据类型来接(Date,String,Long,还是别的什么?),各层和各个方法之间传递的时候以什么类型传?
  4. 当某些字段需要通过RestController接口返回给前端的时候,ResDTO的字段类型又要如何设计,是 String、Date 还是通过某种注解配合字段来实现?
  5. 后端java方法中,使用什么类型传递呢? Date,String,Long,还是别的什么?
  6. 前后端交互的时候,形式要如何确定,是看起来不知所云的数字时间戳呢,还是让某一方转换一次使用人人期待的“yyyy-MM-dd HH:mm:ss” 呢?

在没有一个统一约定的情况下,这些确实是老大难问题。

现在约定一个统一标准。

一、统一标准约束

注:以下内容都经过验证,非凭空臆想。

  1. myslq表设计中,固定字段 create_time, update_time 字段使用timestamp格式,且update_time 勾选“根据当前时间戳更新”
  2. mysql表中的其他表示时间的字段,日期的则使用 date 格式,日期时间的则使用 datetime格式 (因为业务时间可能需要时间范围为很多年之后的情况,比如卖了一个终身有效的课程,超出了timestamp的范围)。
  3. java代码中的DO、BO以及最终返回给前端的ResDTO ,甚至方法之间的传参,都用 java 的 Date 类型。都可以直接接收,不会报错。
  4. ReqDTO中的参数就用java的 Date 格式,前端直接传 “yyyy-MM-dd” 或 “yyyy-MM-dd HH:mm:ss” 即可识别。

如果这样约定的话,则任何地方,我们都不再需要:

  1. 把难以理解,不能望文生义的数值时间戳传来传去和反复转换
    2.各种DateUtil转换,@Date注解以生成“yyyy-MM-dd HH:mm:ss”类型字符串给前端的过程,都不需要了
  2. mybatis映射时,Date 类型直接就能成功,无需额外关心。

二、 为什么可以,以及怎样做

2.1 通常情况 (jackson)

springboot项目中,如果声明一个@RestController 接口,如果返回 Date格式的话,则前端通过http接收到的格式默认为:Tue May 24 2022 17:49:42

这一点想必大家深受其扰。

但实际上,这是因为springboot框架中默认使用了 jackson 进行序列化。我们只需指定一个全局的jackson序列化格式即可,非常简单

application.properties配置文件增加以下配置:

spring.jackson.date-format=yyyy-MM-dd HH:mm:ss
spring.jackson.time-zone=GMT+8

2.2 有些时候 (如 Gson)

有些时候,有的人并不想用默认的jackson序列化内容,于是就采用了自定义的序列化库。

Gson等。


办法:在指定自定义的序列化库的时候,顺便指定Date序列化的格式。

三、完美示例

项目很简单试一下就明白了。

https://download.csdn.net/download/festone000/85465322

或仓库地址:
https://gitee.com/festone/springboot-datetime-demo

内容是一样的。

综上,此做法具备一切优点,没有任何不足,值得大力推广。

四、结合现状(我司现状,其他人不必参考)

但由于现状的原因,返回给前端的不是“yyyy-MM-dd HH:mm:ss”格式,而是 毫秒时间戳格式。

故,我们统一全局配置一下格式,使得:

ResDTO中的Date类型,给前端的时候直接就是毫秒时间戳格式。

毫秒时间戳格式的请求参数,后端也可以直接用Date类型接收。

前后端双方都不需要额外的任何显式转换。

示例(springboot版本 2.1.9.RELEASE,与当前我们项目中用的版本一致):

application.yml文件:

spring:
  jackson:
    # yyyy-MM-dd HH:mm:ss 格式
    #date-format: yyyy-MM-dd HH:mm:ss
    time-zone: GMT+8
    serialization:
      # 毫秒时间戳格式
      write-dates-as-timestamps: true

resDTO 示例:
在这里插入图片描述
java 类型:

@Data
@Builder
@AllArgsConstructor
@NoArgsConstructor
public class XtResponse implements Serializable {
 
    private String name;
 
    private Date date;
}

reqDTO示例:

在这里插入图片描述
java类型:

@Data
@Builder
@AllArgsConstructor
@NoArgsConstructor
public class DateReq implements Serializable {
 
    private String name;
 
    private Date date;
}

综上,完美,具备一切优点,基本上可以说没有任何缺点。

  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2022-06-01 15:02:20  更:2022-06-01 15:03:26 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/27 12:07:23-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码