文章十三: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}}
相关推荐
Dxy12393102161 小时前
Python如何处理树状分类数据
大数据·python·分类
青山师1 小时前
动态代理深度解析:JDK与CGLIB底层实现与实战
java·设计模式·面试·动态代理·java面试·cglib
放学后的泡泡1 小时前
提供一个工作流的表设计
java·设计规范
凡人AI录2 小时前
小红书商业变现 100 个关键词:从流量逻辑到长期复利
大数据
生活真难2 小时前
SpringCloud - 任务调度 - xxl-job-java
java·spring boot·spring cloud
zhongerzixunshi2 小时前
筑牢国家安全防线,赋能企业合规发展
大数据·人工智能·安全
小飞象—木兮2 小时前
2026数据资产入表解决方案(52页 PPT)
大数据·人工智能
Dotrust东信创智2 小时前
革新测试管理3.0:Storm UTP统一测试管理平台全链路追溯与AI赋能升级
大数据·人工智能·storm
人道领域2 小时前
【黑马点评日记】:用户签到功能详解——从Bitmap入门到避坑指南
java·数据库·redis·后端
梦梦代码精2 小时前
《企业开源商城选型:商业闭环、二次开发与成本平衡》
java·开发语言·低代码·开源·github