使用mybatis查询数据时, 数据库日期不能正常显示

我们在使用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>
  • 4
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

javaの历练之路

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值