【问题标题】:Write a query for Array of objects in Elastic Search为 Elastic Search 中的对象数组编写查询
【发布时间】:2019-05-03 12:08:32
【问题描述】:

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

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

姓名、年龄、国家是三个不同的字段,它们的类型是文本。 从前端,输入将像上面所有三个字段与数组的组合一样。

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

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

【问题讨论】:

标签: elasticsearch


【解决方案1】:

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

它看起来有点古怪,但大致翻译为: “找我(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"
                }
              }
            ]
          }
        }
      ]
    }
  }
}

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2012-10-16
    • 2017-06-12
    • 2020-08-18
    • 1970-01-01
    • 2011-08-29
    • 2017-12-28
    • 2019-04-03
    • 2013-08-15
    相关资源
    最近更新 更多