0
点赞
收藏
分享

微信扫一扫

Elasticsearch(006):es中filtered和filter的区别

westfallon 2022-04-01 阅读 65
java后端

文章目录

1. bool 和 filtered

1.1 说明

es 5.0版本更新后,filtered的查询将替换为bool查询。

filtered是比较老的的版本的语法。现在目前已经被bool替代。推荐使用bool。

官方文档地址:链接

1.2 示例使用

老版本写法

GET _search
{
  "query": {
    "filtered": {
      "query": {
        "match": {
          "text": "quick brown fox"
        }
      },
      "filter": {
        "term": {
          "status": "published"
        }
      }
    }
  }
}

新版本的写法

GET _search
{
  "query": {
    "bool": {
      "must": {
        "match": {
          "text": "quick brown fox"
        }
      },
      "filter": {
        "term": {
          "status": "published"
        }
      }
    }
  }
}

2. filter的两种用法

  • 嵌套在bool下

    {
    “query”: {
    “bool”: {
    “must”: {
    “term”: {
    “term”:{“title”:“kitchen3”}
    }
    },
    “filter”: {
    “term”: {
    “price”:1000
    }
    }
    }
    }
    }

  • 在根目录下使用

    {
    “query”:{
    “term”:{“title”:“kitchen3”}
    },
    “filter”:{
    “term”:{“price”:1000}
    }
    }

区别

位置

区别

备注

bool下

在filter query先执行filter,不计算score,再执行query。

如 果还要在搜索结果中执行aggregation操作,filter query聚合的是filter和query之后的结果,而filter聚合的是query的结果

根目录下

根目录中的filter在query后执行。

如果还要在搜索结果中执行aggregation操作,filter query聚合的是filter和query之后的结果,而filter聚合的是query的结果

举报

相关推荐

0 条评论