【问题标题】:elasticsearch nested querieselasticsearch嵌套查询
【发布时间】:2015-09-09 11:17:34
【问题描述】:

我正在从我的数据库中读取我的查询,并在 java 端添加了一些过滤器,但代码不起作用。我将从我的数据库中读取星星之间的部分。抱歉英语不好。我怎样才能让它工作,我的查询是:

{
  "from": 0,
  "size": 100,
  "query": {
    "filtered": **{
      "query": {
        "bool": {
          "should": [
            {
              "match": {
                "text": {
                  "query": "xxx",
                  "slop": 0
                }
              }
            },
            {
              "match": {
                "text": {
                  "query": "xbxxı",
                  "slop": 0
                }
              }
            }
          ],
          "minimum_should_match": 1,
          "boost": 1.0
        }
      }
    }**,
    "query": {
      "myFilter": {
        "filter": {
          "bool": {
            "must": [
              {
                "range": {
                  "date": {
                    "gt": "2015-09-08",
                    "lte": "2015-09-09"
                  }
                }
              },
              {
                "query": {
                  "match": {
                    "page": "1"
                  }
                }
              },
              {
                "range": {
                  "xxxx": {
                    "gt": "0.0"
                  }
                }
              }
            ]
          }
        }
      }
    }
  }
}

【问题讨论】:

    标签: json elasticsearch filter


    【解决方案1】:

    您从数据库加载的过滤器是有效的,但问题是您在 ** 之外定义的查询。

    "query": {
      "myFilter": {
        "filter": {
          "bool": {
            "must": [
              {
                "range": {
                  "date": {
                    "gt": "2015-09-08",
                    "lte": "2015-09-09"
                  }
                }
              },
              {
                "query": {
                  "match": {
                    "page": "1"
                  }
                }
              },
              {
                "range": {
                  "xxxx": {
                    "gt": "0.0"
                  }
                }
              }
            ]
          }
        }
      }
    }
    

    如果您想使用此过滤器,您可以在过滤器中的“查询”之后立即定义它。

    {
    "from": 0,
    "size": 100,
    "query": {
       "filtered":** {
          "query": {
            ...
          }**,
          "filter": {
             "bool": {
                "must": [
                   {
                      "range": {
                         "date": {
                            "gt": "2015-09-08",
                            "lte": "2015-09-09"
                         }
                       }
                    },
                    {
                       "query": {
                           "match": {
                              "page": "1"
                            }
                        }
                     },
                     {  
                        "range": {
                           "xxxx": {
                              "gt": "0.0"
                            }
                        }
                     }
                  ]
               }
             }
          }
       }
     }
    

    【讨论】:

    • 我知道是这样的。但是我从数据库得到的查询是一个正式的查询,所以最后一个括号是关闭过滤的部分,所以过滤器将被放置在查询之外。我想要一个解决方案。
    猜你喜欢
    • 2018-03-08
    • 2018-10-17
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2018-04-28
    • 2016-03-28
    • 1970-01-01
    相关资源
    最近更新 更多