【ElasticSearch 8 边学边教】04. ElasticSearch 8 的 Scripting 操作


前言

上一篇讲了 ES 最基本的 CURD 操作,今天这篇文章呢,主要是讲基于 ScriptingES 的数据进行操作。
首先得有个概念, 什么叫 Scripting 操作呢,其实就是 ES 有默认的脚本语言,允许在我们可以在用 RESTful API 的时候,使用带有逻辑的脚本,来完成更加复杂的操作。

一、Painless 脚本

1.1 特点

使用 Painless 的脚本的话,它有如下几个优点
性能快:比替代品快几倍。
安全:具有方法调用/字段粒度的细粒度白名单。
可选输入:变量和参数可以使用显式类型或动态def类型。
语法:使用Groovy的子集扩展Java的语法,以方便使用。
优化:专为 Elasticsearch 脚本而设计。

说白了其实给我的感觉有点像传统关系型数据库里面的存储过程/函数,都是直接交给 ES 处理,而不是在业务代码上自己操作一堆之后再走常规的 CURD API

1.2 基本语法

1.2.1 更新数据

1.2.1.1 字段普通更新
  1. 针对整型字段的加减,语法参考如下:
POST my_index/_update/2
{
   
  //年龄+1
  "script": "ctx._source.age+=1"
}
//或者这样
POST my_index/_update/3
{
    
  //年龄+1
  "script": {
   
  	"source": "ctx._source.age+=1"
  }
}
  1. 针对数组类型的数据,可以这样操作
POST my_index/_update/2
{
   
  //增加标签
  "script": "ctx._source.hobbies.add('滑雪')"
}
//或者这样
POST my_index/_update/3
{
    
  //年龄+1
  "script": {
   
  	"lang": "painless", //标明使用的脚本语言,默认是 painless
 	
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值