文章十三: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}}
相关推荐
ps酷教程7 小时前
Jackson 解决没有无参构造函数的反序列化问题
java
NiceCloud喜云7 小时前
Opus 4.8 的 Effort Control 怎么选:Low 到 Max 五档策略
android·java·大数据·前端·c++·python·spring
Are_You_Okkk_8 小时前
基于MonkeyCode解析AI研发新模式,根治开发低效痛点
大数据·人工智能·开源·ai编程
_日拱一卒8 小时前
LeetCode:994腐烂的橘子
java·数据结构·算法·leetcode·深度优先
隔窗听雨眠8 小时前
Nginx网关响应慢排查手记
java·服务器·nginx
智慧物业老杨9 小时前
智慧物业合同周期管理系统:从风险预警到智能交接的全流程数智化落地方案
java·人工智能·python
科技AI训练师9 小时前
2026高压清洗泵厂家选择指南:判断标准与选购要点
大数据·人工智能
Percent_bigdata9 小时前
“模数共振”开启产业AI新阶段,重新定义数据治理
大数据·人工智能
源码宝9 小时前
MES系统源码:Java8 + SpringBoot2.7 + MySQL8 + Redis,后端源码清爽易扩展
java·后端·源码·springboot·mes系统·源码二开·mes源码
JAVA社区9 小时前
Java高级全套教程(十)—— SpringCloudAlibaba超详细实战详解
java·开发语言·spring cloud·面试·职场和发展