我试图过滤一个术语以匹配数组中的一个值。
转发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收到了错误。
我该怎么做?
答案 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上重载。