文章目录
前言
上一篇讲了 ES 最基本的 CURD 操作,今天这篇文章呢,主要是讲基于 Scripting 对 ES 的数据进行操作。
首先得有个概念, 什么叫 Scripting 操作呢,其实就是 ES 有默认的脚本语言,允许在我们可以在用 RESTful API 的时候,使用带有逻辑的脚本,来完成更加复杂的操作。
一、Painless 脚本
1.1 特点
使用 Painless 的脚本的话,它有如下几个优点:
性能快:比替代品快几倍。
安全:具有方法调用/字段粒度的细粒度白名单。
可选输入:变量和参数可以使用显式类型或动态def类型。
语法:使用Groovy的子集扩展Java的语法,以方便使用。
优化:专为 Elasticsearch 脚本而设计。
说白了其实给我的感觉有点像传统关系型数据库里面的存储过程/函数,都是直接交给 ES 处理,而不是在业务代码上自己操作一堆之后再走常规的 CURD API
1.2 基本语法
1.2.1 更新数据
1.2.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"
}
}
- 针对数组类型的数据,可以这样操作
POST my_index/_update/2
{
//增加标签
"script": "ctx._source.hobbies.add('滑雪')"
}
//或者这样
POST my_index/_update/3
{
//年龄+1
"script": {
"lang": "painless", //标明使用的脚本语言,默认是 painless