合并或和查询以进行弹性搜索

发布于 2025-01-18 06:14:40 字数 155 浏览 5 评论 0原文

有人可以帮助创建弹性搜索查询,以了解以下情况。

((Field1=Keyword1 AND Field2=Keyword1) OR (Field1=Keyword2 AND Field2=Keyword2) OR ...

先感谢您。

Can someone please help to create elastic search query for below case scenario.

((Field1=Keyword1 AND Field2=Keyword1) OR (Field1=Keyword2 AND Field2=Keyword2) OR ...

Thank you in advance.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

‖放下 2025-01-25 06:14:40

它基本上是一个顶级bool/应该带有嵌套bool/filter

{
  "query": {
    "bool": {
      "minimum_should_match": 1,
      "should": [
        {
          "bool": {
            "filter": [
              {
                "term": {
                  "Field1": "Keyword1"
                }
              },
              {
                "term": {
                  "Field2": "Keyword1"
                }
              }
            ]
          }
        },
        {
          "bool": {
            "filter": [
              {
                "term": {
                  "Field1": "Keyword2"
                }
              },
              {
                "term": {
                  "Field2": "Keyword2"
                }
              }
            ]
          }
        }
      ]
    }
  }
}

It's basically a top-level bool/should with nested bool/filter

{
  "query": {
    "bool": {
      "minimum_should_match": 1,
      "should": [
        {
          "bool": {
            "filter": [
              {
                "term": {
                  "Field1": "Keyword1"
                }
              },
              {
                "term": {
                  "Field2": "Keyword1"
                }
              }
            ]
          }
        },
        {
          "bool": {
            "filter": [
              {
                "term": {
                  "Field1": "Keyword2"
                }
              },
              {
                "term": {
                  "Field2": "Keyword2"
                }
              }
            ]
          }
        }
      ]
    }
  }
}
无声无音无过去 2025-01-25 06:14:40

您可以使用的最简单的方法之一是

{
  "query": {
    "query_string": {
      "query": "((Field1:Keyword1 AND Field2:Keyword1) OR (Field1:Keyword2 AND Field2:Keyword2) OR (Field2:Keyword2))"
    }
  }
}

one of the simplest you can use is Query String type of query from Elasticsearch. this will create bool query internally.

{
  "query": {
    "query_string": {
      "query": "((Field1:Keyword1 AND Field2:Keyword1) OR (Field1:Keyword2 AND Field2:Keyword2) OR (Field2:Keyword2))"
    }
  }
}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文