2021-05-06

在数据库中定义的startRunTime为Times 

mysql中定义为Timestamp

在数据库表中startRunTime定义的为Date类型。

但是最后将数据库中的数据转换为Po对象的时候,出现了第一张图的问题,startRunTime格式显示有错误。没有经过格式化的数据 

使用@JsonFormat时间格式化注解使用解决问题

 

@JsonFormat注解是一个时间格式化注解,比如我们存储在mysql中的数据是date类型的,当我们读取出来封装在实体类中的时候,就会变成英文时间格式,而不是yyyy-MM-dd HH:mm:ss这样的中文时间,因此我们需要用到JsonFormat注解来格式化我们的时间。

JsonFormat注解是jackson包里面的一个注解,因此在使用的时候需要引入fasterxml maven的jar包,如下所示。

 
  1. <dependency>

  2. <groupId>com.fasterxml.jackson.core</groupId>

  3. <artifactId>jackson-databind</artifactId>

  4. <version>2.9.2</version>

  5. </dependency>

引入fasterxml maven jar包之后,就可以在实体类属性上面使用@JsonFormat注解了,要注意的是,它只会在类似@ResponseBody返回json数据的时候,才会返回格式化的yyyy-MM-dd HH:mm:ss时间,你直接使用System.out.println()输出的话,仍然是类似“Fri Dec 01 21:05:20 CST 2017”这样的时间样式。

 

 
  1. package demo;

  2. import java.util.Date;

  3. import com.fasterxml.jackson.annotation.JsonFormat;

  4.  
  5. public class Student {

  6. private int id;

  7. private String username;

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

  10. private Date createDate;

  11.  
  12. //getter setter省略。。。

  13.  
  14. }

 

当我们这样@ResponseBody输出json数据的时候,@JsonFormat注解标识的date属性就会自动返回yyyy-MM-dd HH:mm:ss样式的时间了,例如。

 

 
  1. @PostMapping("/api/getStudent")

  2. @ResponseBody

  3. public Map<String,Object> findStudentById(Long stuId){

  4. Map<String,Object> resultMap = new HashMap<>();

  5. Student stu = StudentService.findStudentById(stuId);

  6. resultMap.put("result",stu);

  7. return resultMap;

  8. }

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值