1

我正在尝试过滤一个术语以匹配数组中的一个值。

中继 ES https://www.elastic.co/guide/en/elasticsearch/guide/current/_finding_multiple_exact_values.html

 GET /my_store/products/_search
            {
                "query" : {
                    "filtered" : {
                        "filter" : {
                            "terms" : { 
                                "price" : [20, 30]
                            }
                        }
                    }
                }
            }

我试过这个:

    val res =  ESclient.execute {
        search in "index" query {
          filteredQuery query {
            matchall
          } filter {
                   termsFilter("category", Array(1,2))
          }
        }

但是从 ES 得到一个错误。

我怎样才能做到这一点?

4

1 回答 1

3

当调用 termsFilter 时,该方法需要一个 var args 调用Any*,所以termsFilter("category", 1, 2)会起作用。但是termsFilter("category", Array(1,2))被视为单个参数,因为 Array 当然是 Any 的子类。通过添加: _ *,我们强制 scala 将其视为 vars arg 调用。

所以这将起作用:

val res =  ESclient.execute {
  search in "index" query {
    filteredQuery query {
      matchall
   } filter {
        termsFilter("category", Array(1,2) : _ *)
   }
}

也许最好的解决方案是更新客户端以在 Iterables 上重载。

于 2015-06-10T11:51:06.213 回答