如何使用 searchkick 进行逻辑运算的复杂查询
How to do complex querying with logical operations by using searchkick
我正在使用 searchkick 库作为产品搜索的 elasticsearch 客户端。
https://github.com/ankane/searchkick
可以创建'OR'条件和'AND'条件;
AND运算
Product.search 其中:{价格:{lte: 200},in_stock:真}
或运算
Product.search 其中:{或:[[{in_stock: true}, {延期交货:true}]]}
但我坚持使用 searchkick 创建 多个 'AND' 'OR' 条件。
我需要类似的东西
A 或 B 或(C 和 D)
或者我需要这样,
A 与 B 与(C 或 D)
请指导我,如何实现这个
谢谢
A 或 B 或(C 和 D)
Product.search where: {or: [[{brand: 'nike'}, {in-stock: true}, {price: {lte: 12}, color: 'red'}]]}
A 与 B 与(C 或 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"}]]}]]}
我正在使用 searchkick 库作为产品搜索的 elasticsearch 客户端。 https://github.com/ankane/searchkick
可以创建'OR'条件和'AND'条件;
AND运算 Product.search 其中:{价格:{lte: 200},in_stock:真}
或运算 Product.search 其中:{或:[[{in_stock: true}, {延期交货:true}]]}
但我坚持使用 searchkick 创建 多个 'AND' 'OR' 条件。
我需要类似的东西
A 或 B 或(C 和 D)
或者我需要这样,
A 与 B 与(C 或 D)
请指导我,如何实现这个
谢谢
A 或 B 或(C 和 D)
Product.search where: {or: [[{brand: 'nike'}, {in-stock: true}, {price: {lte: 12}, color: 'red'}]]}
A 与 B 与(C 或 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"}]]}]]}