Elastic4s - 为一个术语查找多个精确值

时间:2015-06-09 15:02:37

标签: scala elasticsearch elastic4s

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

转发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收到了错误。

我该怎么做?

1 个答案:

答案 0 :(得分:3)

调用termsFilter时,该方法需要Any*的var args调用,因此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上重载。