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

Dia*_*ias 6 ruby ruby-on-rails logical-operators elasticsearch searchkick

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

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

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

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

但Iam坚持用searchkick 创建多个' AND''OR '条件.

我需要类似的东西

A OR B OR(C和D)

或者我需要这样的,

A和B和(C或D)

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

谢谢

Dia*_*ias 18

A OR B OR(C和D)

Product.search where: {or: [[{brand: 'nike'}, {in-stock: true}, {price: {lte: 12}, color: 'red'}]]} 
Run Code Online (Sandbox Code Playgroud)

A和B和(C或D)

Product.search where: {brand: 'nike', in-stock: true, or: [ [{price: {lte: 12}}, {color: 'red'}] ]}
Run Code Online (Sandbox Code Playgroud)

更新

(A或B)和(C或D)

 Product.search where: {or: [[ {or: [[{brand: "nike"}, {in-stock: "true"}]]}], [{or: [[{price: 100}, {color: "red"}]]}]]}
Run Code Online (Sandbox Code Playgroud)

  • 为什么地狱或条件有双方括号,我花了很多时间弄清楚它有双方括号.谢谢 (3认同)