• (37)ElasticSearch基于groovy脚本执行partial update


      1、准备数据

    PUT /lib/user/1
    {
        "first_name":"Jane",
        "last_name":"Smith",
        "age":32,
        "about":"I like to collect rock albums",
        "interests":[ "music" ]
    }

      2、操作演示

      (1)age增加1

    GET /lib/user/1/_update
    {
      "script":"ctx._source.age+=1"
    }

      查看结果:GET /lib/user/1

    {
      "_index": "lib",
      "_type": "user",
      "_id": "1",
      "_version": 2,
      "found": true,
      "_source": {
        "first_name": "Jane",
        "last_name": "Smith",
        "age": 33,
        "about": "I like to collect rock albums",
        "interests": [
          "music"
        ]
      }
    }

      (2)改变last_name的值

    GET /lib/user/1/_update
    {
      "script":"ctx._source.last_name+='hehe'"
    }

      查看结果:GET /lib/user/1

    {
      "_index": "lib",
      "_type": "user",
      "_id": "1",
      "_version": 3,
      "found": true,
      "_source": {
        "first_name": "Jane",
        "last_name": "Smithhehe",
        "age": 33,
        "about": "I like to collect rock albums",
        "interests": [
          "music"
        ]
      }
    }

      3)增加一个interests

    GET /lib/user/1/_update
    {
      "script":{
      "source":"ctx._source.interests.add(params.tag)",
      "params":{
        "tag":"football"
      }
    }
    }

      查看结果:GET /lib/user/1

    {
      "_index": "lib",
      "_type": "user",
      "_id": "1",
      "_version": 4,
      "found": true,
      "_source": {
        "first_name": "Jane",
        "last_name": "Smithhehe",
        "age": 33,
        "about": "I like to collect rock albums",
        "interests": [
          "music",
          "football"
        ]
      }
    }

      4)删除一个interests

    GET /lib/user/1/_update
    {
      "script":{
        "source":"ctx._source.interests.remove(ctx._source.interests.indexOf(params.tag))",
        "params":{
           "tag":"football"
         }
      }
    }

      查看结果:GET /lib/user/1

    {
      "_index": "lib",
      "_type": "user",
      "_id": "1",
      "_version": 5,
      "found": true,
      "_source": {
        "first_name": "Jane",
        "last_name": "Smithhehe",
        "age": 33,
        "about": "I like to collect rock albums",
        "interests": [
          "music"
        ]
      }
    }

      5)删除该文档,删除年龄为33的文档

    GET /lib/user/1/_update
    {
      "script":{
        "source":"ctx.op=ctx._source.age==params.count?'delete':'none'",
        "params":{
          "count":33
        }
      }
    }

      查看结果:GET /lib/user/1

    {
      "_index": "lib",
      "_type": "user",
      "_id": "1",
      "found": false
    }

      6)有该文档的话给age增加1,没有添加一个文档

    GET /lib/user/1/_update
    {
      "script":"ctx._source.age+=1",
      "upsert":{
         "first_name": "Jane",
        "last_name": "Smith",
        "age": 18,
        "about": "I like to collect rock albums",
        "interests": [
          "music"
        ]
      }
    }

      查看结果:GET /lib/user/1

    {
      "_index": "lib",
      "_type": "user",
      "_id": "1",
      "_version": 1,
      "found": true,
      "_source": {
        "first_name": "Jane",
        "last_name": "Smith",
        "age": 18,
        "about": "I like to collect rock albums",
        "interests": [
          "music"
        ]
      }
    }
  • 相关阅读:
    python批量插入mysql数据库(性能相关)以及反引号的使用
    python if __name__=='__main__'的理解
    Django学习教程
    python xml文件解析
    对python的super方法的用法理解
    python魔术方法(__init__,__call__,被双下划线包围的方法)
    python进阶书籍 流畅的python
    关于json串的双引号和单引号
    maven 的使用
    学java的目的是大数据和人工智能,勿忘初心!
  • 原文地址:https://www.cnblogs.com/javasl/p/12643716.html
Copyright © 2020-2023  润新知