如何使用searchkick进行逻辑运算的复杂查询

时间:2015-01-08 06:00:00

标签: ruby-on-rails ruby elasticsearch logical-operators searchkick

我使用 searchkick 库作为产品搜索的弹性搜索客户端。 https://github.com/ankane/searchkick

可以创建' OR'条件和' AND'条件;

AND操作 Product.search其中:{price:{lte:200},in_stock:true}

或操作 Product.search where:{或:[[{in_stock:true},{backordered:true}]]}

但Iam坚持创建多个' AND' ' OR' 使用searchkick的条件。

我需要像

这样的东西

A OR B OR(C和D)

或者我需要这样,

A AND B AND(C OR D)

请指导我,如何实现这个

由于

1 个答案:

答案 0 :(得分:15)

A OR B OR(C和D)

Product.search where: {or: [[{brand: 'nike'}, {in-stock: true}, {price: {lte: 12}, color: 'red'}]]} 

A AND B AND(C OR D)

Product.search where: {brand: 'nike', in-stock: true, or: [ [{price: {lte: 12}}, {color: 'red'}] ]}

更新

(A OR B)和(C或D)

 Product.search where: {or: [[ {or: [[{brand: "nike"}, {in-stock: "true"}]]}], [{or: [[{price: 100}, {color: "red"}]]}]]}