首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Searchkick聚合或

Searchkick聚合或
EN

Stack Overflow用户
提问于 2019-01-09 22:41:12
回答 1查看 327关注 0票数 0

我正在用Searchkick搜索产品。它工作得很好,但现在我添加了过滤器。由于产品的性质,我总是想要为所选的过滤器显示,所以而不是使用AND,它总是需要使用OR。

我构建的搜索是这样的:

代码语言:javascript
复制
    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)

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-01-10 20:13:50

在where子句中使用or_参数应该能够获得所需的结果。在Searchkick docs中有一个这样的示例,但对于您的特定场景,以下方法应该有效:

代码语言:javascript
复制
Product.search(
  "shower",
  fields: [:name],
  aggs:   [:showers_ids, :accessories_ids, :bath_ids],
  where:  {
            _or: [
                   {showers_ids:     [46, 41]},
                   {accessories_ids: [104, 102]}
                 ]
          }
)
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54112586

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档