文章十三: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}}
相关推荐
nanxun8866 小时前
记一次诡异的 Docker 容器"串包"故障排查
java
用户1563068103519 小时前
Day01 | Java 基础(Java SE)
java
行者全栈架构师10 小时前
Maven dependency:tree 的 8 个高级用法
java·后端
行者全栈架构师14 小时前
IDEA 中 Maven 项目的 15 个红色报错快速解决方法
java·后端
令人头秃的代码0_015 小时前
mac(m5)平台编译openjdk
java
Elasticsearch1 天前
如何通过 Claude Code 来写入 CSV 数据到 Elasticsearch
elasticsearch
唐青枫2 天前
Java JDBC 实战指南:从 Connection 到事务和连接池
java
一个做软件开发的牛马2 天前
MyBatis-Plus 从零实战:完整搭建可运行 Demo,BaseMapper 零 SQL、Wrapper 条件构造、分页插件与代码生成器详解
java·后端
用户3721574261352 天前
Java 处理 PDF 图片:提取 PDF 中的图片,并压缩 PDF 图片体积
java
用户3721574261352 天前
Java 打印 Word 文档:从基础打印到高级设置
java