栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 前沿技术 > 大数据 > 大数据系统

ElasticSearch修改多层结构中的数据附java代码

ElasticSearch修改多层结构中的数据附java代码

需求:

        多层级关系,需要修改es_KIE下medical_ner,case_info中字段的值

参考网上帖子修改的写法:

request.index(esInfo.getIndex()) //索引名
        .id(timelineSearch.getId())//id
        .doc(
                XContentFactory.jsonBuilder()
                   .startObject()
                   .field("es_KIE.case_info.hosptial",timelineSearch.getHospital())
                   .field("es_KIE.medical_ner.symptom",timelineSearch.getSymptom())
                   .field("es_KIE.medical_ner.cure", timelineSearch.getCure())
                   .field("es_KIE.medical_ner.es_map_cls",timelineSearch.getEsMapCls())
                   .endObject());

 执行完会发现响应"OK",没有报错,但是es库里值未改变

成功修改的写法:(多层嵌套)

        HashMap medicalNerMap = new HashMap<>();
        medicalNerMap.put("symptom",timelineSearch.getSymptom());
        medicalNerMap.put("cure",timelineSearch.getCure());
        HashMap caseInfoMap = new HashMap<>();
        caseInfoMap.put("hospital",timelineSearch.getHospital());
        HashMap esKIEMap = new HashMap<>();
        esKIEMap.put("medical_ner",medicalNerMap);
        esKIEMap.put("case_info",caseInfoMap);
        esKIEMap.put("es_map_cls",timelineSearch.getEsMapCls());
        HashMap bodyMap = new HashMap<>();
        bodyMap.put("es_KIE", esKIEMap);
        UpdateRequest request =
                 new UpdateRequest(esInfo.getIndex(),timelineSearch.getId());
        request.doc(JSON.toJSonString(bodyMap), XContentType.JSON);
        UpdateResponse response =         
                 restHighLevelClient.update(request,RequestOptions.DEFAULT);
捕获下异常就可以

KQL:
POST common_dev/_update/0000739386_00
{
    "doc":{
        "es_KIE":{
          "medical_ner":{
            "symptom":["xxx","xxx"],
            "cure":["xxx",
                "xxx"]
          },
          "case_info":{
            "hospital":"xxxx"
          },
          "es_map_cls":"xxxx"
        }  
    }
}









        

 

 

                

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/389281.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号