小编典典

如何使用searchkick通过逻辑操作进行复杂查询

elasticsearch

Iam使用 searchkick 库作为 Elasticsearch 客户进行产品搜索。
https://github.com/ankane/searchkick

可以创建“ OR”条件和“ AND”条件;

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

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

但是Iam坚持使用searchkick 创建 多个“ AND”“ OR” 条件。

我需要类似的东西

A OR B OR(C和D)

或者我需要这样,

A AND B AND(C OR D)

请指导我,如何实现这一目标

谢谢


阅读 577

收藏
2020-06-22

共1个答案

小编典典

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或B)和(C或D)

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