国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

Elasticsearch 插入時間字段時數據格式問題

yeyan1996 / 2284人閱讀

摘要:時間格式創建的之后,可以設置。如果中沒有設置的,那么默認為兩種格式其中新版移除了前綴。設置格式轉換類的屬性庫在轉換為的時候,將類型轉為為了型的字符串表示。

elasticsearch 時間格式

elasticsearch創建index的之后,可以設置mapping
如果mapping中沒有設置date的format,那么默認為兩種格式
strict_date_optional_time||epoch_millis ,其中新版strict_date_optional_time移除了前綴strict_

date_optional_time 此格式為ISO8601標準 示例:2018-08-31T14:56:18.000+08:00

epoch_millis 也就是時間戳 示例1515150699465, 1515150699

以上2中是默認的,其他的格式參考官方文檔-format

數據插入

進入默認的格式化格式是以上兩種,那么只用傳入對應的格式即可,想使用哪種格式的時間,就先設置對應field的format。

設置格式

PUT my_index
{
  "mappings": {
    "_doc": {
      "properties": {
        "date": {
          "type":   "date",
          "format": "yyyy-MM-dd"
        }
      }
    }
  }
}

轉換java類的屬性

jackson庫在轉換為json的時候,將Date類型轉為為了long型的字符串表示。我們使用@JsonFormat注解改變格式化的結果

@Field(type = FieldType.Date, format = DateFormat.custom,pattern = "yyyy-MM-dd")
@JsonFormat(shape = JsonFormat.Shape.STRING, pattern ="yyyy-MM-dd",timezone="GMT+8")
private Date callback_at;

如果是默認的date_optional_time 的格式

@Field(type = FieldType.Date, format = DateFormat.date_optional_time)
@JsonFormat(shape = JsonFormat.Shape.STRING, pattern ="yyyy-MM-dd"T"HH:mm:ss.SSSZ",timezone="GMT+8")
private Date callback_at;

其他格式舉一反三即可

參考文檔:
springboot elasticsearch 集成注意事項

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/77008.html

相關文章

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<