Elasticsearch学习--script

news2025/4/9 5:42:00

一、概念

 es1.4-5.0,默认脚本语言是Grovvy

es5.0+,默认脚本语言是painless

 二、简单使用

将price减一

# 将id=1的price减一
POST goods/_update/1
{
  "script": {
    "source": "ctx._source.price -= 1"
  }
}

# 简写
POST goods/_update/1
{
  "script": "ctx._source.price -= 1"
}

其中,ctx是一个上下文对象 ,用在对数据的修改上

三、CRUD

1、数据备份

(数据来源可以查看:CSDN)

#将goods中的数据备份到goods2中
POST _reindex
{
  "source": {
    "index": "goods"
  },
  "dest": {
    "index": "goods2"
  }
}

2. 新增数组中的值

# 将id=1的tags新增一个值
POST goods/_update/1
{
  "script": "ctx._source.tags.add('无线充电')"
}

3. 根据id删除

# 删除id=11的数据
POST goods/_update/11
{
  "script": "ctx.op='delete'"
}

 4. upsert

如果数据存在执行script中的内存,如果数据不存在,执行upsert中内存

POST goods/_update/15
{
  "script": {
    "source": "ctx._source.price += 100"
  },
  "upsert": {
    "name":"香蕉",
    "price": 599
  }
}

第一次执行结果

 第二次执行结果

 5. 查询

使用expression和painless两种语言进行查询,查询结果相同

GET goods/_search
{
  "script_fields": {
    "new_price": {
      "script": {
        "lang": "expression",
        "source": "doc['price'].value * 0.9"
      }
    }
  }
}

GET goods/_search
{
  "script_fields": {
    "new_price": {
      "script": {
        "lang": "painless",
        "source": "doc['price'] * 0.9"
      }
    }
  }
}

painless,doc['age'].value和doc['age']都能正确输出,但是doc['age'] * 0.9报错
expression,doc['age'].value和doc['age']都能正确输出,doc['age'] * 0.9和doc['age'].value * 0.9也都不报错

但是,painless,如果字段为空,*0.9会报错

expression:只能访问数字、布尔值、日期等,存储的字段不可用

es源数据是map类型的,在取值的时候,要根据doc['xxx']取值

update用ctx,查询的时候用doc

6. 参数化查询

给interest加一个值aaa

POST indexname/_update/2
{
  "script": {
    "lang": "painless",
    "source": "ctx._source.interest.add('aaa')"
  }
}

es在首次执行脚本的时候,会对执行的脚本进行编译,并且把编译的结果放在缓冲区内。es的缓冲区默认只有100M,编译操作很消耗性能,es每分钟支持的编译次数是15次
解决方案是:

POST indexname/_update/2
{
  "script": {
    "lang": "painless",
    "source": "ctx._source.interest.add(params.inserest_name)",
    "params": {
      "inserest_name":"bbb"
    }
  }
}

这样,参数是动态传递的,没有硬编码,下次参数内容发生改变,但是脚本没有发生改变,不需要重新编译,节省性能

同理,也可以这样

GET indexname/_search
{
  "script_fields": {
    "new_age": {
      "script": {
        "lang": "painless",
        "source":"doc['age'].value * params.num",
        "params": {
          "num": 0.9
        }
      }
    }
  }
}

如果是expression,就要把params.num改成num

GET indexname/_search
{
  "script_fields": {
    "new_age": {
      "script": {
        "lang": "expression",
        "source":"doc['age'].value * num",
        "params": {
          "num": 0.9
        }
      }
    }
  }
}

结果数组

GET indexname/_search
{
  "script_fields": {
    "age": {
      "script": {
        "lang": "painless",
        "source":"doc['age'].value"
      }
    },
    "new_age": {
      "script": {
        "lang": "painless",
        "source":"[doc['age'].value - params.num_1,doc['age'].value - params.num_2,doc['age'].value - params.num_3]",
        "params": {
          "num_1": 1,
          "num_2": 2,
          "num_3": 3
        }
      }
    }
  }
}

四、stored scripts:scripts模板

1. 操作脚本

因为脚本编译比较消耗性能,可以把脚本保存在集群的缓存中

语法

/_scripts/{script_id}

创建脚本

POST _scripts/age_num
{
  "script":{
     "lang": "painless",
     "source":"doc['age'].value - params.num"
  }
}

查看脚本

GET _scripts/age_num

使用脚本

GET indexname/_search
{
  "script_fields": {
    "age": {
      "script": {
        "lang": "painless",
        "source":"doc['age'].value"
      }
    },
    "new_age": {
      "script": {
        "id": "age_num",
        "params": {
          "num": 0.9
        }
      }
    }
  }
}

2. scripting的函数式编程

在source中加""",三个双引号

POST indexname/_update/2
{
  "script": {
    "lang": "painless",
    "source": """
       ctx._source.interest.add(params.inserest_name);
       ctx._source.age-=1;
    """,
    "params": {
      "inserest_name": "bbb"
    }
  }
}

如果name中包含aa:name+bb;否则,不操作。==~是匹配的意思

POST indexname/_update/2
{
  "script": {
    "lang": "painless",
    "source": """
      if(ctx._source.name ==~ /[\s\S]*aa[\s\S]*/){
        ctx._source.name+="bb"
      }else{
        ctx.op="noop"
      }
    """
  }
}

for循环取insterst的总数

GET indexname/_search
{
  "aggs": {
    "agg_insterst": {
      "sum": {
        "script": {
          "lang": "painless",
          "source": """
            int total=0;
            for(int i=0; i<doc['interest.keyword'].length;i++){
              total++;
            }
            return total;
          """
        }
      }
    }
  }
}

doc['filed']:会被加载到内存中,效率更高,更消耗内存,只允许简单类型,object和nested属于复杂类型。推荐
params['_source']['field']:每次都要重新加载,重新解析,可以用于复杂类型
 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/5459.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Cloud Computing之时钟和顺序Time and Ordering

文章目录Total orderImplementation of total orderLinearizabilityFIFO rderImplementation of FIFO-orderHappen-before orderingCausal orderingSummary参考文献&#xff1a;Lamport’s logical clock 这章重点介绍了分布式系统下各种类型的时序&#xff0c;其实在分布式场景…

【Linux】网络配置详解

网络配置一.网络连接测试1.查看宿主机和虚拟机ip(1)查看宿主机ip①宿主机:可视化界面查看ip②宿主机:命令行查看ip(2)查看虚拟机ip①虚拟机:可视化界面查看ip②虚拟机:命令行查看ip2.测试宿主机和虚拟机的网络通信(1).宿主机ping虚拟机(2).虚拟机ping宿主机二.网络连接模式1.桥…

420招募线上被试 | 高素质人才行为心理测试

招募中 【实验任务】高素质人才行为心理测试 【实验时长】18分钟 【实验时间】2022年11月12日00时 - 2022年11月20日24时 【实验地点】线上实验 【实验报酬】微信红包&#xff0c;每份问卷3元 【实验要求】如实回答问卷问题&#xff0c;并提供微博账号和微博地址 【被试要…

Js逆向教程-03浏览器调试工具-Source面板

Js逆向教程-03浏览器调试工具-Source面板 切换到source面板&#xff0c;对于source面板&#xff0c;需要打开搜索面板才能发挥出完整的功能。 一、搜索面板 通过点击右上角的按钮&#xff0c;切换到搜索面板 搜索页面的左侧&#xff0c;可以给搜索页面添加其他功能 比如cons…

第1章 数据结构的概念

文章目录文档配套视频讲解链接地址第01章 数据结构的概念1.1 数据结构的知识体系1.2 链表1. 创建头结点的内存图2. 插入1节点时的内存图3. 插入2节点时的内存图4. 插入3节点的内存图5. 实例1 链表节点的插入6. 链表删除节点37. 实例2 链表的删除节点8. 实例3 链表的改查逆序9. …

Allegro阻抗分析指导书

Allegro阻抗分析指导书 利用Allegro自带的功能可以快速分析信号的阻抗 操作如下 首先用172版本打开PCB 把每层厚度和介电常数填写进去 点击work flow Manager,出现右图对话框 选择需要查看的网络 点击start Analysis 点击impedance table和impedance vision就可以查看阻…

【网络篇】第九篇——多线程版的TCP网络程序

多进程与多线程对比 多进程 多线程 多线程版的TCP网络程序 多进程与多线程对比 多进程 优点 可以处理多个用户易于边写稳定&#xff0c;因为进程具有独立性 缺点 连接来了之后才创建进程&#xff0c;性能太低多进程服务器特别吃资源&#xff0c;而且同时服务的客户有上限…

(最新版2022版)剑指offer之排序题解

&#xff08;最新版2022版&#xff09;剑指offer之排序题解JZ3数组中重复的数字JZ51 数组中的逆序对JZ40 最小的K个数JZ41 数据流中的中位数JZ3数组中重复的数字 思路&#xff1a; 既然数组长度为nnn只包含了0到n−1n-1n−1的数字&#xff0c;那么如果数字没有重复&#xff0c…

qt C++中指针自动释放内存及程序中的内存操作、管理

程序加载到内存后代码存储到代码区&#xff0c;并将全局变量、静态变量初始化到全局/静态内存区&#xff0c;然后会分配2M左右的栈内存区用于存储局部变量&#xff0c;并在运行时根据需要可以在堆内存区(空闲内存区及硬盘的虚拟内存区)申请空间。 程序可使用的内存分区↓ 各基…

C++之Hello World

概览 编程语言历史 机器语言:00110101…最初始的计算机内部语言,不同机器使用的语言甚至不同 汇编语言:利用简单符号(a DB 7H…)对机器语言进行了一定的抽象,增加了可读性,更加人性化.在一定程度上仍然依赖硬件,属于低级的语言 高级语言:使用文字通过编译器被翻译为机器语言…

Vue中 引入使用 element-resize-detector 监听 Dom 元素 宽度、高度 变化

1. 前言 很多做pc端平台的小伙伴都遇到过这样一个问题&#xff1a;在做侧边栏菜单时会有一个收缩和展开的一个功能&#xff0c;在伸缩的过程中右边的页面的宽度就会随之改变。我上网查了查 &#xff0c;也动手试了试 window.onresize ()>{}。却不尽人意&#xff0c;因为它…

SVM 超平面计算例题

SVM Summary Example Suppose the dataset contains two positive samples x(1)[1,1]Tx^{(1)}[1,1]^Tx(1)[1,1]T andx(2)[2,2]Tx^{(2)}[2,2]^Tx(2)[2,2]T, and two negative samples x(3)[0,0]Tx^{(3)}[0,0]^Tx(3)[0,0]T and x(4)[−1,0]Tx^{(4)}[-1,0]^Tx(4)[−1,0]T. Please…

MySQL纯代码复习

前言 本文章是用于总结尚硅谷MySQL教学视频的记录文章&#xff0c;主要用于复习&#xff0c;非商用 原视频连接&#xff1a;https://www.bilibili.com/video/BV1iq4y1u7vj/?p21&spm_id_frompageDriver&vd_sourcec4ecde834521bad789baa9ee29af1f6c https://www.bilib…

C#重启 --- 枚举

第一部分 --- 枚举 枚举类型的本质其实就是在给整型数据加标签&#xff0c;当编译器遇到枚举类型标签的时候&#xff0c;编译器会自动获取标签对应的整型数据&#xff08;默认从0开始由上往下递增&#xff09; 枚举类型的使用方法&#xff1a; 1.枚举类型的类型名是由我们自己…

四.STM32F030C8T6 MCU开发之利用 TIM1+ADC1+DMA1 实现5路(3路外部电压模拟信号+内部2路信号)采集

四.STM32F030C8T6 MCU开发之利用 TIM1ADC1DMA1 实现5路&#xff08;3路外部电压模拟信号内部2路信号&#xff09;采集 文章目录四.STM32F030C8T6 MCU开发之利用 TIM1ADC1DMA1 实现5路&#xff08;3路外部电压模拟信号内部2路信号&#xff09;采集0.总体功能概述ADC 简介1.ADC硬…

数据结构《LinkeList 双向链表》

LinkeList LinkeList 的低层是由双向链表结构组成的&#xff0c;所有元素都是存放到单独的节点当中&#xff0c;通过地址引用将节点串联起来 因此在任意位置插入或删除元素时&#xff0c;都不在需要移动元素&#xff0c;效率较高 下面是双向链表的结构图&#xff1a; 在集合框…

【从零开始游戏开发】静态资源优化 | 全面总结 |建议收藏

你知道的越多&#xff0c;你不知道的越多 &#x1f1e8;&#x1f1f3;&#x1f1e8;&#x1f1f3;&#x1f1e8;&#x1f1f3; 点赞再看&#xff0c;养成习惯&#xff0c;别忘了一键三连哦 &#x1f44d;&#x1f44d;&#x1f44d; 文章持续更新中 &#x1f4dd;&#x1f4dd;…

C++智能指针

文章目录一、智能指针的目的和基本原理二、不带引用计数的智能指针2.1 auto_ptr2.2 scoped_ptr2.3 unique_ptr三、带引用计数的智能指针3.1 shared_ptr3.2 weak_ptr一、智能指针的目的和基本原理 一般new出来的对象会用普通指针引用&#xff0c;此时申请的堆上的资源需要我们手…

乐趣国学—品读《弟子规》中的“泛爱众”之道(上篇)

前言 “泛爱众”就是以广泛的爱心对待社会大众。人类生活是以爱心为纽带&#xff0c;没有爱心&#xff0c;人类生活就太痛苦不堪了。这个爱心从哪里来的&#xff1f;这个爱心就是孝心。孝道&#xff0c;正是培养爱心的第一步&#xff0c;一个连父母都不爱的人决不会真心爱他人&…

19.Feign 的工程化实例:eureka,ribbon,feign,hystrix(springcloud)

项目模型 项目结构 本实例创建model都是通过maven手动创建&#xff0c;依赖进行手动导入&#xff0c;好处是比使用springboot模板创建更加灵活&#xff0c;更方便的进行父子模块的管理。 1.创建父项目feign-project 2.对父项目feign-project的pom.xml&#xff0c;进行手动导入依…