码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • elasticsearch 之时间类型


    日期类型(Date datatype)

    JSON 没有日期类型,因此在 Elasticsearch 中可以表达成:

    • 日期格式化的字符串,比如: “2015-01-01” 或者 “2015/01/01 12:10:30”;
    • 毫秒级别的 long 类型
    • 秒级别的 integer 类型,

    比如: 1515150699465, 1515150699;
    实际上不管日期以何种格式写入,在 ES 内部都会先换成 UTC 时间并存储为 long 类型。

    日期格式可以自定义,如果没有指定的话会使用以下的默认格式:
    “strict_date_optional_time||epoch_millis”

    date 类型的查询在内部转为 long 处理,聚合返回的结果再根据字段定义的格式转为字符串输出。

    注: 日期将始终呈现为字符串,即使它们最初是在 JSON 文档中作为 long 串提供的。

    日期格式自定义,如果没有格式指定,它会使用以下默认设置:

    "strict_date_optional_time||epoch_millis"

    如:
    PUT my_index
    {
      "mappings": {
        "_doc": {
          "properties": {
            "date": {
              "type": "date" 
            }
          }
        }
      }
    }
    
    PUT my_index/_doc/1
    { "date": "2015-01-01" } 
    
    PUT my_index/_doc/2
    { "date": "2015-01-01T12:10:30Z" } 
    
    PUT my_index/_doc/3
    { "date": 1420070400001 } 
    
    GET my_index/_search
    {
      "sort": { "date": "asc"} 
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26

    注:sort 返回为数组,值均为毫秒时间戳。

    多日期格式设置

    PUT my_index
    {
      "mappings": {
        "_doc": {
          "properties": {
            "date": {
              "type":   "date",
              "format": "yyyy-MM-dd HH:mm:ss||yyyy-MM-dd||epoch_millis"
            }
          }
        }
      }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13

    设置参数

    • boost 默认 1.0
    • doc_values 默认 true
    • format 默认 strict_date_optional_time||epoch_millis
    • locale
    • ignore_malformed 是否忽略非正常格式的值,默认 false,抛出异常
    • index 是否可被查询 默认 true
    • null_value 默认值 null
    • store 默认 false

    常用 format

    • epoch_millis
    • epoch_second

    参考

    1.https://www.elastic.co/guide/en/elasticsearch/reference/6.4/date.html
    2.https://www.elastic.co/guide/en/elasticsearch/reference/6.4/mapping-date-format.html

  • 相关阅读:
    在TX2平台编译安装飞桨Paddlepaddle
    【问题解决】我遇到并解决PlatformIO无法使用的各种问题汇总及解决方法,简单粗暴使用的网络问题解决方法...
    嵌入式经验分享:面试薪资直接翻番,我才明白TA的重要性!
    招投标系统软件源码,招投标全流程在线化管理
    下篇:技术 Leader 的思考方式
    Navicat Premium连接Django项目的数据库
    Linux文件与目录的增删改查
    nodejs+vue+elementui高校新闻管理系统
    hadoop2.2.0伪分布式搭建
    基础 | JVM - [参数]
  • 原文地址:https://blog.csdn.net/web15085599741/article/details/126358952
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号