ELK filter 查询

filter 查询不计算相关性,同时可以 cache ,因此 filter 速度要快于 query.

POST /lib4/items/_bulk
{"index":{"_id":1}}
{"price":40,"itemID":"ID100123"}
{"index":{"_id":2}}
{"price":50,"itemID":"ID100124"}
{"index":{"_id":3}}
{"price":25,"itemID":"ID100124"}
{"index":{"_id":4}}
{"price":30,"itemID":"ID100125"}
{"index":{"_id":5}}
{"price":null,"itemID":"ID100127"}

 

// 过滤价格从 25,到 40 的 文档

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

// 查找 itemID 为 ID100023 的文档

GET /lib4/items/_search
{
   "query":{
     "bool":{
       "filter":[
          {"term":{"itemID":"ID100123"}}
        ]
     }
   }
}

// 返回的记录中查找不到该文档

{
  "took" : 0,
  "timed_out" : false,
  "_shards" : {
    "total" : 5,
    "successful" : 5,
    "skipped" : 0,
    "failed" : 0
  },
  "hits" : {
    "total" : 0,
    "max_score" : null,
    "hits" : [ ]
  }
}

原因是在使用 _bluk 动态创建mapping是 将 itemID 自动识别为 text 类型。所以在存储的时候讲 itemID 的数据中的大写在分词的时候进行了小写处理。

GET /lib4/items/_mapping

解决方法:

①:在查找的时候使用小写。

②:使用 match 查询

 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值