登录
首页 >  数据库 >  MySQL

为 Elasticsearch 设置 update_time(qbit)

来源:SegmentFault

时间:2023-01-17 14:16:52 224浏览 收藏

大家好,今天本人给大家带来文章《为 Elasticsearch 设置 update_time(qbit)》,文中内容主要涉及到MySQL、时间戳,如果你对数据库方面的知识点感兴趣,那就请各位朋友继续看下去吧~希望能真正帮到你们,谢谢!

前言

  • 本文对 Elasticsearch 7.13 有效
  • 创建时间(create_time)没找到好的实现方式
  • 如果入库的数据不再更新,文中的 update_time 可等同于 create_time

update_time 示例

PUT _ingest/pipeline/add_update_time
{
  "processors": [
    {
      "script": {
        "lang": "painless",
        "source": """DateFormat df = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ssX"); df.setTimeZone(TimeZone.getTimeZone("Asia/Shanghai")); Date date = new Date(); ctx.update_time = df.format(date);"""
      }
    }
  ]
}
  • 创建索引,并设置默认 pipeline

PUT my_index
{
  "settings": {
    "index.default_pipeline": "add_update_time"
  }
}
  • 插入数据

POST my_index/_doc/1
{
  "title": "nothing"
}
  • 查看 mapping

GET my_index/_mapping

{
  "my_index" : {
    "mappings" : {
      "properties" : {
        "title" : {
          "type" : "text",
          "fields" : {
            "keyword" : {
              "type" : "keyword",
              "ignore_above" : 256
            }
          }
        },
        "update_time" : {
          "type" : "date"
        }
      }
    }
  }
}
  • 查询数据

GET my_index/_search
{
  "query": {
    "range": {
      "update_time": {
        "time_zone": "+08",        
        "gte": "2021-07-28T16:00:00", 
        "lte": "now"                  
      }
    }
  }
}

{
  "took" : 0,
  "timed_out" : false,
  "_shards" : {
    "total" : 1,
    "successful" : 1,
    "skipped" : 0,
    "failed" : 0
  },
  "hits" : {
    "total" : {
      "value" : 1,
      "relation" : "eq"
    },
    "max_score" : 1.0,
    "hits" : [
      {
        "_index" : "my_index",
        "_type" : "_doc",
        "_id" : "1",
        "_score" : 1.0,
        "_source" : {
          "update_time" : "2021-07-28T18:03:35+08",
          "title" : "nothing"
        }
      }
    ]
  }
}
本文出自 qbit snap

好了,本文到此结束,带大家了解了《为 Elasticsearch 设置 update_time(qbit)》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多数据库知识!

声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>
评论列表