欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

springboot mybatis里localdatetime序列化問題的解決

 更新時間:2018年10月09日 13:42:49   作者:張占嶺  
這篇文章主要介紹了springboot mybatis里localdatetime序列化問題,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

問題起因

主要是使用mybatis作為ORM之后,返回的對象為Map,然后對于數(shù)據(jù)庫的datetime,datestamp類型返回為時間戳而不是標準的時間,這個問題解決方案有兩種,大叔分析一下:

1.在mapper的select里,使用mysql這些數(shù)據(jù)庫的函數(shù),dateformat進行轉(zhuǎn)化,缺點,單元測試里使用h2數(shù)據(jù)庫時會找不到這些函數(shù)

2.在ObjectMapper反序列化時統(tǒng)一進行處理,這種方式更好,與具體數(shù)據(jù)庫解耦了

實現(xiàn)

>引用依賴包

 'org.mybatis:mybatis-typehandlers-jsr310:1.0.2',
 'com.fasterxml.jackson.datatype:jackson-datatype-jsr310:2.9.2'

>添加組件類

/**
 * 序列化localdatetime處理.
 */
@Component
public class JacksonConfig {

 /**
 * 注入時間處理.
 *
 * @return
 */
 @Bean
 @Primary
 public ObjectMapper objectMapper() {
 ObjectMapper mapper = new ObjectMapper();
 mapper.registerModule(new JSR310Module());
 mapper.setDateFormat(new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss.SSS'Z'"));
 return mapper;
 }

}

>成功解決問題

{
 "pageCurrent": 1,
 "pageSize": 10,
 "pageTotal": 1,
 "data": [
  {
   "freeDays": 8,
   "city": "",
   "leadingPerson": "",
   "contactPerson": "zhangsan",
   "source": 1,
   "customerName": "i-counting",
   "intention": 1,
   "province": "",
   "appointmentTime": "2018-09-20T00:00:00.000Z",
   "createTime": "2018-09-27T06:33:49.000Z",
   "telephoneStatus": 1,
   "id": 10000,
   "contactPhone": "135"
  }
 ]
}

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

最新評論