资深患者 2022-09-05 17:04 采纳率: 0%
浏览 14
已结题

ElasticSearch Nested字段查询问题

环境:ES为7.10.2

数据-成员表,大概结构如下:

主键Id标题成员数据(nested结构:uid,uname)
11d1uid="f1",uname="灰太狼"、uid="f2",uname="蜗牛"
22d2uid="f1",uname="灰太狼"
PUT /f_data
{
  "mappings": {
    "properties": {
      "id":{"type": "keyword"},
      "title":{"type": "wildcard"},
      "members":{
        "type": "nested",
        "properties": {
          "uid":{"type":"keyword"},
          "uname":{"type":"wildcard"}
        } 
      }
    }
  }
}

测试数据如下:

PUT f_data/_doc/11
{"id":"11","title":"d1","members":[{"uid":"f1","uname":"灰太狼"},{"uid":"f2","uname":"蜗牛"}]}
PUT f_data/_doc/22
{"id":"22","title":"d2","members":[{"uid":"f1","uname":"灰太狼"}]}

针对members字段做 “无指定用户(uid)的数据”查询查询

查询条件:查询 members中无 f1 用户的数据
实现方式:基于nested查询+must_not查询
期望结果:无返回数据
实际结果:返回了d1数据

问题:如何通过查询实现此类需求

查询语句如下:

POST f_data/_search?filter_path=hits.hits._source
{
  "query": {
    "nested": {
      "path": "members",
      "query": {
        "bool": {
          "must_not": [
            {"term": {"members.uid": {"value": "f1"}}}
          ]
        }
      }
    }
  }
}

执行结果:

{
  "hits" : {
    "hits" : [
      {
        "_source" : {
          "id" : "11",
          "title" : "d1",
          "members" : [
            {
              "uid" : "f1",
              "uname" : "灰太狼"
            },
            {
              "uid" : "f2",
              "uname" : "蜗牛"
            }
          ]
        }
      }
    ]
  }
}

  • 写回答

1条回答

      报告相同问题?

      相关推荐 更多相似问题

      问题事件

      • 系统已结题 9月14日
      • 已采纳回答 9月6日
      • 创建了问题 9月5日

      悬赏问题

      • ¥15 ue如何做自然的物体边缘磨损效果材质
      • ¥15 求解答,急,本人真的是没有办法了
      • ¥15 我是在windows环境下通过IIS部署django项目,但是是这样怎么处理呢
      • ¥15 python 循环语句问题
      • ¥30 51单片机测量脉冲周期/频率并加以计算、显示
      • ¥50 图书期刊管理系统c++
      • ¥20 c语言基础,设计带界面的小应用
      • ¥15 Erplab无法创建事件清单
      • ¥15 fdisk输入n后不提示选择分区类型
      • ¥15 关于#java#snaker 工作流的问题,如何解决?