zoukankan      html  css  js  c++  java
  • (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"
        ]
      }
    }
  • 相关阅读:
    JS 利用数组拼接html字符串
    IE浏览器下读取客户端上传的文件大小
    PrintWriter out = response.getWriter() 输出中文乱码问题
    非常有用的Java程序片段
    sql之left join、right join、inner join的区别
    JAVA 数组常用技巧
    java 图片文件格式转换(多页tif转jpg 、jpg转tif)
    SQL Server 字段状态判断语句
    sql server 2008中id如何设为自增
    java基于xml配置的通用excel单表数据导入组件(五、Action处理类)
  • 原文地址:https://www.cnblogs.com/javasl/p/12643716.html
Copyright © 2011-2022 走看看