博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Es学习第八课, Filter、bool和范围查询
阅读量:6800 次
发布时间:2019-06-26

本文共 1226 字,大约阅读时间需要 4 分钟。

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

你可能感兴趣的文章
node c++ addon注意事项
查看>>
hdu 3501(欧拉函数引申)
查看>>
django-request获取数据
查看>>
python的eval、exec函数使用总结
查看>>
js解析与序列化json数据(一)
查看>>
Oracle升级前备份和失败回退
查看>>
学习笔记之PostgreSQL / pgAdmin / Psycopg / PostGIS
查看>>
java设计模式-工厂方法模式
查看>>
SAP RFC通信模式
查看>>
基于jQuery+JSON的省市联动效果
查看>>
NABCD构建APP
查看>>
React 获取 url 参数 —— this.props.match
查看>>
乙佳荣第二次作业
查看>>
request请求的常用属性
查看>>
13-JS中的面向对象
查看>>
[转载]LeetCode: Gray Code
查看>>
优达学城数据分析师纳米学位——知识点总结2
查看>>
.Net 调用中国气象台Web Service
查看>>
BNU 51002 BQG's Complexity Analysis
查看>>
leetcode 7. Reverse Integer
查看>>