猿猿猿灬 2022-07-18 11:40 采纳率: 33.3%
浏览 21
已结题

ES查询不出预期结果

ES查询不出预期结果

ES索引

PUT /goods
{
    "mappings": {
        "goods": {
            "properties": {
                "id": {
                    "type": "keyword"
                },
                "goods_list": {
                    "type": "nested",
                    "include_in_parent": true,
                    "properties": {
                        "name": {
                            "type": "keyword"
                        },
                        "price": {
                            "type": "keyword"
                        }
                    }
                }
            }
        }
    }
}

ES数据

{
    "_source": {
        "id": "1",
        "goods_list": [
            {
                "name": "mi1",
                "price": "1999"
            },
            {
                "name": "mi2",
                "price": "4999"
            }
        ]
    },
    "_source": {
        "id": "2",
        "goods_list": [
            {
                "name": "mi3",
                "price": "3999"
            },
            {
                "name": "mi2",
                "price": "4999"
            }
        ]
    }
}
ES查询语句
GET /goods/_search
{
  "query": {
    "nested": {
      "path": "goods_list",
      "query": {
        "bool": {
          "must": [
            {
              "match": {
                "goods_list.price": 
                  "1999"
              }
            },
            {
              "match": {
                "goods_list.price": 
                  "4999"
              }
            }
          ]
        }
      }
    }
  }
}
运行结果及报错内容

通过这个查询语句想匹配到goods_list中包含价格为1999和4999的记录,但是这个查询语句查无结果。
但是把goods_list修改为非nested类型的,就可以查询到结果。
这种用法是否正确? 及其原因?及正确的解决办法?

  • 写回答

2条回答 默认 最新

  • 皮蛋不吃粥 2022-07-18 13:31
    关注

    因为这里的bool操作是对同一个嵌套文档进行查询,也就是要查询同一个文档下,满足price 1999和price 4999显然不存在,是同一个嵌套文档,而不是同一个goods_list,当你改为Object他会扁平成键值对,所以可以查询到

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 8月16日
  • 已采纳回答 8月8日
  • 创建了问题 7月18日

悬赏问题

  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测