Es学习第八课, Filter、bool和范围查询

Filter过滤查询 

filter是不计算相关性的,同时可以缓存。因此filter速度快于query。

我们先在kibana上先添加数据来做准备

POST /lib4/items/_bulk
{ "index": { "_id": 1 }}
{ "price" : 40, "itemID" : "ID1001" }
{ "index": { "_id": 2 }}
{ "price" : 50, "itemID" : "ID1002" }
{ "index": { "_id": 3 }}
{ "price" : 25, "itemID" : "ID1004" }
{ "index": { "_id": 4 }}
{ "price" : 30, "itemID" : "ID1004" }
{ "index": { "_id": 5 }}
{ "price" : null, "itemID" : "ID1005" }

首先,我们过滤查询价格等于40的文档,如下写法

GET /lib4/items/_search
{
  "query": {
    "bool": {
      "filter": [
       { "term":{"price":40}}
        ]
    }
  }
}

 

bool过滤查询

bool查询可以实现组合过滤查询

格式:

{"bool" : {"must":[],"should":[],"must_not":[] } }

must:必须满足的条件 (相当于and)

should:可以满足也可以不满足的条件 (相当于or)

must_not:不需要满足的条件 (相当于not) 

GET /lib4/items/_search  #满足价格是25或者ID是1004,同时价格不为30
{
  "query": {
    "bool":{
      "should": [
        {"term":{"price": 25}},
        {"term":{"itemID": "id1004"}}
      ],
      "must_not": [
        {"term":{"price": 30}}
      ]
    }
  }
}

范围过滤

gt:>

lt:<

gte:>=

lte:<=

GET /lib4/items/_search   #range表示取一定范围的数据
{
  "query": {
    "bool":{
       "filter": {
         "range": {
           "price": {
             "gt": 25,
             "lte": 50
           }
         }
       }
    }
  }
}

 

转载于:https://www.cnblogs.com/kakatadage/p/9959424.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值