這個問題,惡心的一批。。無力吐槽
原文地址:https://blog.csdn.net/m0_38043362/article/details/78855196?utm_source=blogxgwz8
導致這個問題的原因,網上搜了一下,大概意思是:spring轉json的默認實現jackson中會根據時區去轉換時間,而jackson的默認時區跟國內是相差8小時的,所以這里得重新設置當前項目地所在時區。
1. application.yml 或者application.properties 文件中數據庫連接方式追加時區設置serverTimezone=GMT+8,這里轉換+號為 %2b 后使用
spring: datasource: # 主數據源 datasource: driverClassName: com.mysql.jdbc.Driver jdbc-url: jdbc:mysql://localhost:3306/ga_qhfj_microffice?useUnicode=true&characterEncoding=utf-8&serverTimezone=GMT%2b8&useSSL=false username: root password: root
2. application.properties 或 application.yml添加配置
#application.properties文件配置 spring.jackson.time-zone=GMT+8 ------------------------------------ #application.yml文件配置 spring: jackson: time-zone: GMT+8
3.返回的實體類使用注解@JsonFormat
public class ArticleListVo { private Long articleId; @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",timezone="GMT+8") private Date createTime; }
2019.6.10
這些方法都有些問題,本來我用的是第二種,結果發現有問題的時間戳正常了項目中其他地方的個別的時間戳又錯了,還是用最笨的辦法吧
在實體中多加兩個String屬性用來接收日期
在sql語句中將出問題的時間轉成字符串,在起個加的字段名稱的別名,在頁面中展示着兩個新加的屬性
sql中Data 轉 字符串 方法如下
DATE_FORMAT(table.start_time,'%Y-%m-%d %h:%i:%s') AS startTimenew
DATE_FORMAT(table.end_time,'%Y-%m-%d %h:%i:%s') AS endTimenew,
問題解決。。