我们在使用mybatis查询数据库的日期数据时,如果数据库存储的是timestamp、datetime、date、time等时间类型,而且Java 实体类也使用date类型,那么mybatis会自动将date类型转换为unix long类型,如:
解决方式有三种:
1.将Java实体类中的日期类型改为String类型,在插入日期的时候需要进行转换,略麻烦。
2.在java实体类中date类型上加上注解@JsonFormat ,这样获取到的值就是正常的日期格式了,如:
@Data
public class TaskVo {
private Integer taskId;
private String taskName;
private String taskClass;
private Integer runType;
private Integer runStatus;
private String executeCron;
@JsonFormat(pattern="yyyy-MM-dd HH:mm:ss",timezone = "GMT+8")
private Date loadTime;
}
其中@Date是lombok包下的一个注解,引入该注解后,不需要在实体类中写set/get方法亦可调用实体类的set/get方法。在pattern中可定义日期格式,timezone代表时区,GMT+8是东八区的意思。
结果:
依赖:
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-annotations</artifactId>
<version>2.2.3</version>
</dependency>
3.如果页面使用的时jsp,那么可以在日期显示的地方加入如下代码:
<td><fmt:formatDate value="${list.loadTime}" pattern="yyyy-MM-dd HH:mm:ss" type="date"></td>