【MybatisPlus】对数据库中datetime类型字段的处理(获取与格式处理)

博客介绍了数据库中Datetime类型字段对应Java实体类的Date和LocalDateTime数据类型的区别,Date可变且无时区信息,LocalDateTime不可变。还提及对时间类型数据输出信息的格式化,可通过引入jackson依赖,采用全局配置或对字段分别设置的方式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

        数据库中Datetime类型字段可以对应Java实体类中的Date数据类型或LocalDateTime数据类型。但这两种数据类型直接却有着很大的区别,被用在不同的应用场景中。(一般推荐使用LocalDateTime,有更多的灵活性和功能)

private Date createTime;
private Date updateTime;
// 或者
private LocalDateTime createTime;
private LocalDateTime updateTime;

一、Data数据类型与LocalDateTime数据类型的区别

        Date数据类型属于java.util包,是Java的一个日期和时间类,它代表特定时刻的时间戳,存储的是自1970年1月1日以来的毫秒数,但不包含时区信息,对时区不敏感。且Date数据类型是可变的,可以通过setTime(long time)来设置时间戳。

        LocalDateTime数据类型属于java.time包,是Java 8引入的新日期和时间API的一部分,它代表了一个日期和时间,但没有时区信息,若要处理时区信息可以使用ZonedDateTime类。而LocalDateTime数据类型不可变,一旦创建LocalDateTime对象,它的值将不会改变。若想要修改值,只能创建一个新的LocalDateTime对象。

        LocalDateTime的基本使用可以看下面这篇文章:

【Java LocalDateTime】LocalDateTime获取时间信息、格式化、转换为数字时间戳icon-default.png?t=N7T8https://blog.csdn.net/zxy2361380031/article/details/134344872

二、对时间类型数据输出信息的格式化

 这里需要引入jackson依赖来format时间的数据类型:

<!-- jackson -->
<dependency>
    <groupId>com.fasterxml.jackson.core</groupId>
    <artifactId>jackson-databind</artifactId>
    <version>2.15.3</version>
</dependency>

         方法一:  (全局配置)

        在springBoot的配置文件中添加以下代码可以实现全局配置:

# application.properties的配置如下:

spring.jackson.date-format=yyyy-MM-dd HH:mm:ss # 时间格式
spring.jackson.time-zone=GMT+8                 # 时区
# application.yaml的配置如下:

spring:
  jackson:
    date-format: yyyy-MM-dd HH:mm:ss # 时间格式
    time-zone: GMT+8                 # 时区

        方法二:  (对字段分别设置)

        通过对字段添加@JsonFormat注解来设置该字段的时间格式,比较繁琐,但更加灵活。

@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",timezone="GMT+8")
private LocalDateTime startTime;

@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",timezone="GMT+8")
private LocalDateTime endTime;

三、格式

yyyy
MM
dd
HH
mm
ss

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

狐笙

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

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

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

打赏作者

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

抵扣说明:

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

余额充值