首页 最新 热门 推荐

  • 首页
  • 最新
  • 热门
  • 推荐

【Elasticsearch复合查询】

  • 25-03-07 17:41
  • 2138
  • 10842
blog.csdn.net

Elasticsearch复合查询

在Elasticsearch中,复合查询(Compound Queries)是用来封装其他复合查询或叶子查询的查询类型。它们的主要目的是组合这些查询的结果和分数、改变它们的行为或者从查询上下文切换到过滤上下文。

一个常见的复合查询是bool查询,它允许你通过布尔逻辑组合多个查询条件。bool查询包含以下几种子句:

  • must: 文档必须匹配所有must子句下的查询条件,并且这些匹配会影响到文档的相关性评分。
  • should: 文档可以匹配should子句下的一个或多个查询条件,这会增加文档的相关性评分。如果没有任何must子句存在,至少需要满足一个should子句。
  • must_not: 文档不能匹配任何must_not子句下的查询条件。这个子句不会影响评分,它的作用是排除不相关的文档。
  • filter: 文档必须匹配filter子句下的查询条件,但与must不同的是,filter子句不会影响文档的评分,只起到过滤的作用。

除了bool查询之外,还有其他的复合查询类型,例如:

  • constant_score 查询:将原始查询转换为不计算评分的过滤查询,并给所有匹配的文档赋予相同的评分。
  • dis_max 查询:用于指定一个查询中的多个子查询,并返回那些单个最佳匹配子查询得分最高的文档。
  • function_score 查询:允许你修改查询结果的评分,可以通过定义不同的函数来调整最终的评分。

代码示例

1. bool 查询

bool 查询是使用最广泛的复合查询之一。它允许你通过布尔逻辑组合多个查询条件。

  • must: 文档必须匹配这些条件,相当于 AND。
  • filter: 必须匹配,但不计算相关性分数。
  • should: 文档应该匹配这些条件中的至少一个,增加其相关性分数。
  • must_not: 文档不能匹配这些条件。

示例代码:

{
  "query": {
    "bool" : {
      "must" : {
        "term" : { "user" : "kimchy" }
      },
      "filter": {
        "term" : { "tag" : "tech" }
      },
      "must_not" : {
        "range" : {
          "age" : { "from" : 10, "to" : 20 }
        }
      },
      "should" : [
        { "term" : { "comment" : "cool" } },
        { "term" : { "comment" : "wonderful" } }
      ]
    }
  }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
2. dis_max 查询

dis_max 查询会选择单个最佳匹配的查询子句来计算最终分数,而不是像 bool 查询那样合并所有匹配子句的分数。

示例代码:

{
  "query": {
    "dis_max" : {
      "queries" : [
        { "match" : { "title" : "Quick pets" }},
        { "match" : { "body" : "Quick pets" }}
      ],
      "tie_breaker" : 0.7
    }
  }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
3. function_score 查询

function_score 允许你修改查询结果的评分,根据特定的函数调整每个文档的最终评分。

示例代码:

{
  "query": {
    "function_score": {
      "query": { "match_all": {} },
      "functions": [
        {
          "filter": { "match": { "test": "bar" }},
          "weight": 23
        },
        {
          "filter": { "match": { "test": "cat" }},
          "weight": 42
        }
      ],
      "score_mode": "max",
      "boost_mode": "multiply"
    }
  }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19

使用复合查询可以帮助你构建复杂的搜索逻辑,以精确地控制哪些文档应该被检索出来以及如何对它们进行排序。根据你的具体需求,你可以选择合适的复合查询类型来实现你的查询目标。

注:本文转载自blog.csdn.net的龙少9543的文章"https://blog.csdn.net/qq_44734705/article/details/145132497"。版权归原作者所有,此博客不拥有其著作权,亦不承担相应法律责任。如有侵权,请联系我们删除。
复制链接
复制链接
相关推荐
发表评论
登录后才能发表评论和回复 注册

/ 登录

评论记录:

未查询到任何数据!
回复评论:

分类栏目

后端 (14832) 前端 (14280) 移动开发 (3760) 编程语言 (3851) Java (3904) Python (3298) 人工智能 (10119) AIGC (2810) 大数据 (3499) 数据库 (3945) 数据结构与算法 (3757) 音视频 (2669) 云原生 (3145) 云平台 (2965) 前沿技术 (2993) 开源 (2160) 小程序 (2860) 运维 (2533) 服务器 (2698) 操作系统 (2325) 硬件开发 (2492) 嵌入式 (2955) 微软技术 (2769) 软件工程 (2056) 测试 (2865) 网络空间安全 (2948) 网络与通信 (2797) 用户体验设计 (2592) 学习和成长 (2593) 搜索 (2744) 开发工具 (7108) 游戏 (2829) HarmonyOS (2935) 区块链 (2782) 数学 (3112) 3C硬件 (2759) 资讯 (2909) Android (4709) iOS (1850) 代码人生 (3043) 阅读 (2841)

热门文章

132
搜索
关于我们 隐私政策 免责声明 联系我们
Copyright © 2020-2025 蚁人论坛 (iYenn.com) All Rights Reserved.
Scroll to Top