使用elasticsearch原子操作更新
短信预约 -IT技能 免费直播动态提醒
本篇文章向大家介绍《使用elasticsearch原子操作更新》,主要包括,具有一定的参考价值,需要的朋友可以参考一下。
问题内容func (d *Dynamic) Like(ctx *gin.Context) {
var (
req message.Like
err error
buf bytes.Buffer
)
if err = ctx.ShouldBind(&req); err != nil {
d.ResponseJson(ctx, 400, err.Error(), nil)
return
}
doc := map[string]interface{}{
"doc": map[string]interface{}{
"like_number": 1,
},
}
if err := json.NewEncoder(&buf).Encode(doc); err != nil {
fmt.Printf("%v", err.Error())
}
resp, err := config.Global.ES.Update("live_dynamic_list", req.DynamicId, &buf, config.Global.ES.Update.WithDocumentType("doc"))
fmt.Printf("%v", resp)
if err != nil {
d.ResponseJson(ctx, 400, err.Error(), nil)
return
}
d.ResponseJson(ctx, 200, "success", nil)
}
- 我希望在自身基础上实现 like_number + 1
- 例如,like number当前值为69,执行代码后应该+1,即70。
- 我使用的包是 github.com/elastic/go-elasticsearch/v7
解决方案
通常会执行原子更新(例如就地增量)via scripts:
POST live_dynamic_list/_update/doc_id
{
"script" : {
"source": "ctx._source.like_number += params.increment",
"lang": "painless",
"params" : {
"increment" : 1
}
}
}
Here's how 您可以在 go
中使用此类更新脚本。
理论要掌握,实操不能落!以上关于《使用elasticsearch原子操作更新》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注编程网公众号吧!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341