es日期时间匹配的规则,底层是如何比较日期和时间的以及按照时间查询的几种方式

最近研究es的日期匹配问题,知道es的底层是存储Unix时间戳,并且录入的时间是可以有时区的信息的。
目前数据存储有三个数据,两个是0时区数据,一个是东八区数据:

{
    {
        "date": "2015-01-01T12:10:30Z"
    }
},
{
    {
        "date": "2015-01-01T12:10:30"
    }
},
{
    {
        "date": "2015-01-01T12:10:30+08:00"
    }
}

当用没带时区信息的语句查询时,三条记录都可以查询出来:

{
    "query": {
        "range" : {
            "date" : {
                "gte": "2015-01-01 01:10:30",
                "lte": "2015-01-01 11:10:30",
                "format": "yyyy-MM-dd hh:mm:ss||yyyy"
            }
        }
    }
}

当用带有时区的查询时,就可以精确查询:(只查询出一条)

{
    "query": {
        "range" : {
            "date" : {
                "gte": "2015-01-01T01:10:30",
                "lte": "2015-01-01T11:10:30"
            }
        }
    }
}

想请问es内部对时间的匹配规则是什么样的?用什么数据结构?

答案:如果没带时区信息的都会转换为0时区数据(长整形),上面的问题中,使用了hh:mm:ss来进行格式化数据,hh会把时间格式化到pm时段,数据就变大了

es 按照时间查询的几种格式

GET m-2fg-day/_search
{
  "size": 0,
  "query": {
    "bool": {
      "filter": [
        {
          "term": {
            "2fg_year": "2017"
          }
        },
        {
          "term": {
            "2fg_month": "09"
          }
        },
        {
          "term": {
            "2fg_day": "25"
          }
        }
      ]
    }
  },
  "aggs": {
    "uncertain_reason": {
      "terms": {
        "field": "uncertain_reason.keyword",
        "size": 10
      }
    }
  }
}

GET gather-034-20180302/_search
{
  "query": {
    "bool": {
      "must": [
        {
          "range": {
            "report_time": {
              "gte": "2018-03-02T09:39:12.000Z",
              "lte": "2018-03-02T13:00:00.000Z"
            }
          }
        },
        {
          "term": {
            "itv_account": {
              "value": "AD87218665@ITV4"
            }
          }
        }
      ]
    }
  }
}

GET gather-000/_search
{
  "size": 0,
  "query": {
    "range": {
      "@timestamp": {
        "gte": "2017-08-30T00:00:00",
        "lte": "2017-08-30T23:59:59",
        "time_zone": "+08:00"
      }
    }
  }
}

GET gather-034-20180316/_search
{
  "_source": {
    "include": [
      "report_time",
      "flr"
    ]
  },
  "query": {
    "bool": {
      "must": [
        {
          "range": {
            "flr": {
              "gte": 30
            }
          }
        },
        {
          "term": {
            "area": {
              "value": "SC_CD"
            }
          }
        },
        {
          "range": {
            "report_time": {
              "gte": "now-30m"
            }
          }
        }
      ]
    }
  },
  "aggs": {
    "1": {
      "terms": {
        "field": "itv_account",
        "size": 10
      },
      "aggs": {
        "2": {
          "avg": {
            "field": "flr"
          }
        }
      }
    }
  },
  "sort": [
    {
      "report_time": {
        "order": "desc"
      }
    }
  ]
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

戴国进

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值