当前位置: 首页 > backend >正文

【Elasticsearch】scripted_upsert

在 Elasticsearch 中,`scripted_upsert` 是一个用于更新操作的参数,它允许在文档不存在时通过脚本初始化文档内容,而不是直接使用 `upsert` 部分的内容。这种方式提供了更灵活的文档创建和更新逻辑。

 

`scripted_upsert` 的工作原理

当设置 `scripted_upsert` 为 `true` 时,Elasticsearch 会根据脚本逻辑来处理文档的创建和更新,而不是直接使用 `upsert` 部分的内容。脚本可以根据文档是否存在来执行不同的逻辑。

 

- 文档不存在时:脚本会初始化文档内容。

- 文档存在时:脚本会更新文档内容。

 

使用场景

`scripted_upsert` 常用于以下场景:

1. 复杂的初始化逻辑:当文档不存在时,需要通过脚本动态生成初始内容,而不是直接插入固定的 `upsert` 数据。

2. 统一的更新逻辑:无论文档是否存在,都希望通过脚本统一处理更新逻辑。

 

示例

以下是一个使用 `scripted_upsert` 的示例,展示了如何根据文档是否存在来执行不同的脚本逻辑:

 

```json

POST /sessions/session/1/_update

{

  "scripted_upsert": true,

  "script": {

    "source": "if (ctx.op == 'create') { ctx._source = params.newData } else { ctx._source.counter += params.increment }",

    "lang": "painless",

    "params": {

      "newData": {

        "counter": 1,

        "name": "Initial Name"

      },

      "increment": 5

    }

  },

  "upsert": {}

}

```

 

在这个例子中:

- 如果文档不存在,脚本会使用 `params.newData` 初始化文档。

- 如果文档存在,脚本会将 `counter` 字段增加 `params.increment` 的值。

 

注意事项

- `upsert` 部分:即使设置了 `scripted_upsert`,`upsert` 部分仍然需要提供一个空对象 `{}`,否则会报错。

- 脚本语言:脚本通常使用 Painless 语言编写,这是一种 Elasticsearch 提供的安全脚本语言。

- 性能考虑:脚本执行会增加一定的计算开销,因此在高并发场景下需要注意性能优化。

 

通过 `scripted_upsert`,Elasticsearch 提供了一种灵活的方式来处理文档的创建和更新逻辑,特别适用于需要动态生成初始内容或统一更新逻辑的场景。

http://www.xdnf.cn/news/9406.html

相关文章:

  • 小白成长之路-计算机网络(四)
  • BUG调试案例十二:LM5117输出电压纹波偏大问题案例
  • 初识 ProtoBuf
  • 破解Docker镜像下载难题
  • 永磁同步电机控制算法--变结构PI调节器
  • 面向测试编程——SmartRefreshLayout的测试case
  • Ubuntu系统开放 45876/tcp 端口
  • Cookie、Session和Token鉴权
  • Python实用脚本:可视化分割txt标签数据
  • TWTSolutions水厂污水厂设计计算软件:化学强化絮凝单元
  • leetcode:1688. 比赛中的配对次数(python3解法,数学相关算法题)
  • ubuntu安装tigervnc
  • Python优雅执行SSH命令:10种方法+虚拟环境深度实践
  • 使用 mysqldump 获取 MySQL 表的完整创建 DDL
  • Spring AI(一)
  • windows 环境中 python连接到达梦库,及相关问题解决办法
  • TDengine 中的存储配置
  • 线程池详解:原理、使用与优化
  • 78. Subsets和90. Subsets II
  • Linux:基础指令与内涵理解(下)与权限
  • git 命令之-git cherry-pick
  • 短剧看广告APP系统开发:打造高效变现与用户体验双赢平台
  • 人工智能AI之机器学习基石系列 第 2 篇:数据为王——机器学习的燃料与预处理
  • JavaSE核心知识点04工具04-04(Git)
  • 专业教育机构视频网站平台播放器页面如何处理视频加密的?
  • [React]实现一个类zustand公共状态库
  • 2025上半年软考系统架构设计师选择题试题与答案
  • AI Agents执行流程和决策流程学习
  • 零基础设计模式——结构型模式 - 组合模式
  • RapidOCR4j项目学习