ES 脚本核心语法:ctx._source [‘group_id‘]

复制代码
updateByQueryRequest.setScript(new Script(
    Script.DEFAULT_SCRIPT_TYPE,
    Script.DEFAULT_SCRIPT_LANG,
    "if(ctx._source['group_id']==null){" +
    "    ctx._source['group_id']= params.groupIds" +
    "} else if(!ctx._source['group_id'].contains(params.groupId)) {" +
    "    ctx._source['group_id'].add(params.groupId)" +
    "}",
    params
));

1. 核心概念:ctx 是"上下文"

你可以把 ctx 想象成一个**"快递员"**。

  • 当 ES 找到你要修改的那条数据时,它不会直接把数据扔给你。
  • 它会把这个数据包装在一个"信封"里,交给快递员 ctx
  • 你想拿数据,就得跟快递员要:ctx.你要的东西

所以,ctx 就是**"当前操作的环境"** ,它是你进入当前文档的唯一入口

2. 第二层:_source 是"原始包裹"

接上上面的比喻:

  • 快递员 ctx 把信封给你了。
  • 信封上写着几个字:_source 。这代表**"原始数据"**。
  • ES 里存的文档(Document),本质上就是一个 JSON 对象。在 ES 内部,这个 JSON 对象被存放在 _source 这个字段下。

举个例子:

你存进 ES 的是一张卡片(文档):

复制代码
{
  "name": "张三",
  "age": 25,
  "group_id": ["group_001"]
}

在 ES 的底层存储里,它其实是长这样子的(简化版):

复制代码
{
  "_index": "profile_index",
  "_type": "_doc",
  "_id": "1",
  "_source": {  // 👈 看这里!
    "name": "张三",
    "age": 25,
    "group_id": ["group_001"] // 👈 你的数据其实藏在这里面
  }
}

所以,_source 就是那个装着你真实数据的"盒子"。

3. 第三层:['group_id'] 是"盒子里的具体东西"

  • 既然数据都在 _source 这个盒子里,那你想要改 group_id,就得打开盒子去找。
  • ctx._source 就是拿到了那个盒子。
  • ctx._source['group_id'] 就是打开了盒子,拿出了里面叫 group_id 的那张纸条。

4. 连起来解释

现在我们看这行代码:

复制代码
ctx._source['group_id'] = params.groupIds

翻译成人话就是:

"快递员(ctx),请把你的'原始数据盒子'(_source)打开,找到里面叫 group_id 的那张纸条,把新的值(params.groupIds)写上去。"

5. 为什么不能直接写 group_id

你可能会问:"既然我在脚本里,为什么不能直接写 group_id = ...?"

原因有两个:

  1. 作用域问题:脚本运行在一个沙箱里,它不知道你外面的变量叫什么。你必须明确告诉它:"我要改的是文档里的这个字段"。
  2. 特殊标记_source 是 ES 定义的元字段(Meta-field)。它告诉 ES:"我要修改的是文档的主体内容,而不是文档的 ID 或者其他元数据"。
相关推荐
chilavert3189 分钟前
技术演进中的开发沉思-371:final 关键字(中)
java·前端·数据库
海边的Kurisu14 分钟前
Mybatis-Plus | 只做增强不做改变——为简化开发而生
java·开发语言·mybatis
识君啊18 分钟前
Java 二叉树从入门到精通-遍历与递归详解
java·算法·leetcode·二叉树·深度优先·广度优先
daidaidaiyu33 分钟前
一文学习 Spring AOP 源码全过程
java·spring
毕设源码-郭学长1 小时前
【开题答辩全过程】以 高校人事管理系统 为例,包含答辩的问题和答案
java
Zhu_S W1 小时前
Kubernetes (K8s) 完全指南:Java 开发者的容器编排实践
java·容器·kubernetes
罗超驿2 小时前
15. Java异常处理全解析:从底层原理到实战避坑指南
java·异常处理·开发实战·编程技巧·自定义异常·try-catch
柒.梧.2 小时前
吃透Spring Bean:生命周期、单例特性、作用域及扩展方式
java·后端·spring
zihan03212 小时前
若依(RuoYi)框架核心升级:全面适配 SpringData JPA,替换 MyBatis 持久层方案
java·开发语言·前端框架·mybatis·若依升级springboot
神奇大叔3 小时前
Java 配置文件记录
java·开发语言