我正在用Searchkick搜索产品。它工作得很好,但现在我添加了过滤器。由于产品的性质,我总是想要为所选的过滤器显示,所以而不是使用AND,它总是需要使用OR。
我构建的搜索是这样的:
Product.search(
"shower",
fields: [:name]
where: {showers_ids: [46,41], accessories_ids: [104, 102]},
aggs: [: showers_ids, : accessories_ids, : bath_ids]
)这是在尝试查询:
其中IN (46或41) AND (104或102)
这将始终不会返回任何产品,因为产品只属于一个类别。但我想展示所有类别的产品,所以它需要像这样:
其中IN (46或41)或(104或102)
发布于 2019-01-10 20:13:50
在where子句中使用or_参数应该能够获得所需的结果。在Searchkick docs中有一个这样的示例,但对于您的特定场景,以下方法应该有效:
Product.search(
"shower",
fields: [:name],
aggs: [:showers_ids, :accessories_ids, :bath_ids],
where: {
_or: [
{showers_ids: [46, 41]},
{accessories_ids: [104, 102]}
]
}
)https://stackoverflow.com/questions/54112586
复制相似问题