文章十三:ElasticSearch数据更新实战

数据更新过程

注意:多并发下更新操作没有任何的事务性隔离,在并发情况下,出现严重的数据错位问题。

单条数据更新:

使用PUT进行全量覆盖:

复制代码
PUT <index_name>/_doc/1
{
    "name":"lijia"
}

单条局部更新:

只是修改需要修改的字段就行了。

POST index_test/_update/1

{

"doc": {

"name":"lizi"

}

}

doc_as_upsert 参数,如果当前id的数据不存在的话,是否使用插入的方式新增数据

使用脚本修改数据

使用脚本更新的时候需要进行一下字段的判断:

通过脚本的方式将age进行更新

复制代码
POST index_test/_update/1
{
  "script": {
    "source": """
    ctx._source.age+=100;
    """,
    "lang": "painless"
  }
}

"scripted_upsert": false参数:

如果当前文档不存在时,时候强制执行脚本,默认是false,如果是true的话,就会执行。

复制代码
POST index_test/_update/1
{
  "script": {
    "source": """
     if (ctx._source.age != null) {
        ctx._source.age += 100;
      }
    """,
    "lang": "painless"
  },
  //如果当前数据不存在,将数值设置成默认值
  "upsert": {
    "age":100
  },
//文档不存在时,是否执行脚本
  "scripted_upsert": false
}

使用脚本将没有用的字段进行进行删除

使用脚本将字段age删除,这个是一个小小的技巧

复制代码
POST index_test/_update_by_query?wait_for_completion=true
{
  "query": {
    "match": {
      "name": "lihua"
    }
  },
  "script": {
    "source": """
    ctx._source.remove('age')
    """,
    "lang": "painless"
  }
}

批量更新

复制代码
POST _bulk
{"update":{"_index":"index_test","_id":"1"}}
{"doc":{"name":"lihua"}}
{"update":{"_index":"index_test","_id":"1"}}
{"doc":{"age":10}}
相关推荐
qq_5470261791 分钟前
Java 中的 Caffeine 缓存详解
java·开发语言·缓存
沐雪轻挽萤13 分钟前
15. C++17新特性-std::string_view
java·开发语言·c++
Elastic 中国社区官方博客19 分钟前
Elasticsearch:快速近似 ES|QL - 第二部分
大数据·数据库·sql·elasticsearch·搜索引擎·全文检索
Cisyam^20 分钟前
Bright Data Web Scraping 指南:用 MCP + Dify 自动采集 TikTok 与 LinkedIn数据
大数据·前端·人工智能
devilnumber29 分钟前
java的NIO框架Netty、Mina、Grizzly 和 Jetty 四种对比
java·nio·java面试·jetty
captain_AIouo29 分钟前
Captain AI功能全景解析——从选品到物流的智能闭环
大数据·人工智能·经验分享·aigc
努力进修32 分钟前
【java-数据结构】Java优先级队列揭秘:堆的力量让数据处理飞起来
java·开发语言·数据结构
亚历克斯神32 分钟前
Java 代码质量与静态分析:2026 实战指南
java·spring·微服务
@hhr32 分钟前
使用java对接火山方舟doubao-seedance-1.5-pro 模型进行视频生成
java·python·音视频
廋到被风吹走33 分钟前
【LangChain4j】Java 生态中最灵活、功能最强大的纯 Java 大模型应用开发框架(支持声明式@AiService与复杂RAG/Agent)
java·开发语言·python