bool查询不支持过​​滤器

时间:2016-10-27 05:56:18

标签: elasticsearch-2.0

这是使用ES 2.0抛出异常的查询:

bool query does not support filter

如何使用存在和丢失查询?

查询:

{
   "bool":{
      "must":[
         {
            "bool":{
               "should":[
                  {
                     "bool":{
                        "must":[
                           {
                              "range":{
                                 "startDate":{
                                    "lte":"2016-10-27T11:24:49.6616538+05:30"
                                 }
                              }
                           }
                        ],
                        "filter":[
                           {
                              "bool":{
                                 "must_not":[
                                    {
                                       "exists":{
                                          "field":"endDate"
                                       }
                                    }
                                 ]
                              }
                           }
                        ]
                     }
                  }
               ]
            }
         }
      ]
   }
}

1 个答案:

答案 0 :(得分:3)

首先,该错误通常来自1.x版本的Elasticsearch。 (在这种情况下,您需要FilteredQuery

接下来,您会看到许多级别的不必要的嵌套。不确定是否可能剥离其他东西以制作一个更简单的例子。我已经像这样重写了你的查询(并添加了外括号):

{
    "query" : {
        "bool" : {
            "must" : [{
                    "range" : {
                        "startDate" : { "lte" : "2016-10-27T11:24:49.6616538+05:30" }
                    }
                }
            ],
            "filter" : [{
                    "bool" : {
                        "must_not" : [{
                                "exists" : { "field" : "endDate"    }
                            }
                        ]
                    }
                }
            ]} } 
}

您的原始查询和我重写的查询都可以在我的服务器上正常工作(v2.3.1),所以我猜你真的有ES 1.x吗?

此外,如果您没有利用lucene评分,只想返回文档(或应用您自己的排序),那么您可以完全删除过滤器并进一步简化:

{
    "query" : {
        "bool" : {
            "must" : [{
                    "range" : {
                        "startDate" : { "lte" : "2016-10-27T11:24:49.6616538+05:30"}
                    }
                }
            ],
            "must_not" : [{
                    "exists" : { "field" : "endDate"    }
                }
            ]} } 
}