【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 提供了一种灵活的方式来处理文档的创建和更新逻辑,特别适用于需要动态生成初始内容或统一更新逻辑的场景。

适配器模式(Adapter Pattern)是一种结构型设计模式,它允许将一个类的接口转换成客户端所期望的另一个接口。它通常用于解决两个已有接口之间不兼容的问题。 在给出的代码示例中,我们可以看到适配器模式的应用。在Main.cpp文件中,创建了一个Target对象指针target,并将其初始化为Adapter对象。然后调用target的request()函数,实际上调用的是Adapter的request()函数。而Adapter的request()函数内部调用了Adaptee的specificRequest()函数,完成了适配的过程。 在Head.h文件中定义了三个类:Target、Adaptee和Adapter。Target类是适配器模式中的目标接口,定义了一个虚函数request()。Adaptee类是被适配的类,它有一个特殊的请求函数specificRequest()。Adapter类是适配器类,它继承了Target类,并在其request()函数中调用了Adaptee类的specificRequest()函数。 通过适配器模式,我们可以将不兼容的两个接口进行适配,使它们能够协同工作。这在软件开发中经常用于复用已有代码或集成多个系统。 参考: C++设计模式之适配器模式Adapter Head.cpp Main.cpp<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [C++设计模式之适配器模式(Adapter)](https://download.csdn.net/download/weixin_38666785/12761879)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [C++设计模式-适配器模式](https://blog.csdn.net/qq78442761/article/details/95766831)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值