/**
* 创建时间
*/
@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