springboot时间注解

本文探讨了在Spring Boot 2.1.8环境中,如何解决由于MySQL升级导致的时间不匹配问题,重点在于JsonFormat注解的应用和调整数据库连接的serverTimezone设置为Asia/Shanghai。

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

    /**
     * 创建时间
     */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
	private LocalDateTime startTime;

@JsonFormat注解是一个时间格式化注解,比如我们存储在mysql中的数据是date类型的,当我们读取出来封装在实体类中的时候,就会变成英文时间格式,而不是yyyy-MM-dd HH:mm:ss这样的中文时间,因此我们需要用到JsonFormat注解来格式化我们的时间
小编理解是把数据库的时间转化为人性化的json串,要不然可能就是这样的2021-08-09T00:00:00.000+0000,有点反人性了
@DateTimeFormat 把前端传过来的时间转化为数据库的时间
前后的时间比数据库存储的时间多了八个小时,出现了这个时间不匹配。我目前的环境是:、
springboot版本

 <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.1.8.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>

mysql版本:

 <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.17</version>
        </dependency>

我以前的数据库连接: jdbc:mysql://127.0.0.1:3306/online_coupon?useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=GMT%2B8
在网上查看资料发现,是数据库版本提高之后出现的问题: 把数据库连接更改为serverTimezone=Asia/Shanghai即可。完整链接:jdbc:mysql://127.0.0.1:3306/online_coupon?useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=Asia/Shanghai

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值