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

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条回答 默认 最新

  • 资深患者 2022-09-06 09:10
    关注

    问题已解决:在你nested查询外部使用bool-must_not做约束

    # 查询不存在==未填写;已存在取反,在nested之下取
    POST f_data/_search?filter_path=hits.hits._source
    {
      "query": {
        "bool": {
          "must_not": [
            {"nested": {
              "path": "members",
              "query": {
                "term": {"members.uid": {"value": "f1"}}
              }
            }}
          ]
        }
      }
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

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

悬赏问题

  • ¥15 使用MATLAB进行余弦相似度计算加速
  • ¥15 服务器安装php5.6版本
  • ¥15 我想用51单片机和数码管做一个从0开始的计数表 我写了一串代码 但是放到单片机里面数码管只闪烁一下然后熄灭
  • ¥20 系统工程中,状态空间模型中状态方程的应用。请猛男来完整讲一下下面所有问题
  • ¥15 我想在WPF的Model Code中获取ViewModel Code中的一个参数
  • ¥15 arcgis处理土地利用道路 建筑 林地分类
  • ¥20 使用visual studio 工具用C++语音,调用openslsx库读取excel文件的sheet问题
  • ¥100 寻会做云闪付tn转h5支付链接的技术
  • ¥15 DockerSwarm跨节点无法访问问题
  • ¥15 使用dify通过OpenAI 的API keys添加OpenAI模型时报了“Connection Error”错误