首页 > 解决方案 > 为 Elastic Search 中的对象数组编写查询

问题描述

我正在尝试为以下输入(对象数组)编写查询。

"UserDetails": [                                    
     { "Name" : "Vanaraj", "Age" : "27", "country" : "India" },
     { "Name" : "Ranjit", "Age" : "26", "country" : "US" }
  ]

Name、Age、Country 是三个不同的字段,它们的类型是文本。从前端,输入将像上面所有三个字段与数组的组合一样。

我需要用这三个组合编写一个查询,并根据所有三个字段及其值的组合从索引中过滤记录。“UserDetails”只是一个名称,我提到了仅存在于索引中的三个字段。

使用 {"Name" : "Vanaraj", "Age" : "27", "country" : "India"} 和 { "Name" : "Ranjit", "Age" : "26", "country" : "US" } 和输出应该与这些组合匹配。

标签: elasticsearch

解决方案


如果我正确理解您的问题,我相信您正在寻找这样的东西。

它看起来有点古怪,但大致翻译为:“找到我(Vanaraj,27 岁,在印度)或(Ranjit,26 岁,在美国)”

# Setup a sample index with data
PUT /stackoverflowtest/_doc/1
{ "Name" : "Vanaraj", "Age" : "27", "country" : "India" }
PUT /stackoverflowtest/_doc/2
{ "Name" : "Ranjit", "Age" : "26", "country" : "US" }
PUT /stackoverflowtest/_doc/3
{ "Name" : "Joe", "Age" : "38", "country" : "US" }

# Query that returns Vanaraj / 27 / India or Ranjit / 26 / US
POST /stackoverflowtest/_search
{
  "query": {
    "bool": {
      "should": [
        {
          "bool": {
            "must": [
              {
                "match": {
                  "Name": "Vanaraj"
                }
              },
              {
                "match": {
                  "Age": "27"
                }
              },
              {
                "match": {
                  "country": "India"
                }
              }
            ]
          }
        },
        {
          "bool": {
            "must": [
              {
                "match": {
                  "Name": "Ranjit"
                }
              },
              {
                "match": {
                  "Age": "26"
                }
              },
              {
                "match": {
                  "country": "US"
                }
              }
            ]
          }
        }
      ]
    }
  }
}

推荐阅读