Elasticsearch布尔查询——bool

布尔查询允许我们利用布尔逻辑将较小的查询组合成较大的查询。

1、查询返回包含“mill”和“lane”的所有的账户

curl -XPOST ‘localhost:9200/bank/_search?pretty‘ -d ‘
        {
          "query": {
            "bool": {
              "must": [
                { "match": { "address": "mill" } },
                { "match": { "address": "lane" } }
              ]
            }
          }
        }‘

  在上面的例子中,bool must语句指明了,对于一个文档,所有的查询都必须为真,这个文档才能够匹配成功。

2、查询返回地址中包含“mill”或者“lane”的所有的账户

curl -XPOST ‘localhost:9200/bank/_search?pretty‘ -d ‘
        {
          "query": {
            "bool": {
              "should": [
                { "match": { "address": "mill" } },
                { "match": { "address": "lane" } }
              ]
            }
          }
        }‘

  在上面的例子中,bool should语句指明,对于一个文档,查询列表中,只要有一个查询匹配,那么这个文档就被看成是匹配的。

3、查询返回地址中既不包含“mill”,同时也不包含“lane”的所有的账户

curl -XPOST ‘localhost:9200/bank/_search?pretty‘ -d ‘
        {
          "query": {
            "bool": {
              "must_not": [
                { "match": { "address": "mill" } },
                { "match": { "address": "lane" } }
              ]
            }
          }
        }‘

  在上面的例子中, bool must_not语句指明,对于一个文档,查询列表中的的所有查询都必须都不为真,这个文档才被认为是匹配的。

  我们可以在一个bool查询里一起使用must、should、must_not。此外,我们可以将bool查询放到这样的bool语句中来模拟复杂的、多等级的布尔逻辑。

  下面这个例子返回40岁以上并且不生活在ID(daho)的人的账户:

curl -XPOST ‘localhost:9200/bank/_search?pretty‘ -d ‘
        {
          "query": {
            "bool": {
              "must": [
                { "match": { "age": "40" } }
              ],
              "must_not": [
                { "match": { "state": "ID" } }
              ]
            }
          }
        }‘
时间: 2024-10-01 00:02:44

Elasticsearch布尔查询——bool的相关文章

elasticsearch之布尔查询

前言 布尔查询是最常用的组合查询,根据子查询的规则,只有文档满足所有子查询条件时,elasticsearch 引擎才将结果返回.布尔查询支持的子查询条件共4种 must  (and) should (or) must_not (not) filter 1.must 需求: 查询 from 为 gu  并且 age  为 30  的数据 GET zhifou/doc/_search { "query": { "bool": { "must": [

elasticsearch常用查询

query DSL match 查询 { "match": { "tweet": "About Search" } } 注:match查询只能就指定某个确切字段某个确切的值进行搜索,做精确匹配搜索时, 你最好用过滤语句,因为过滤语句可以缓存数据. match_phrase 查询 { "query": { "match_phrase": { "title": "quick bro

ElasticSearch 索引查询使用指南——详细版

我们通常用用_cat API检测集群是否健康. 确保9200端口号可用: curl 'localhost:9200/_cat/health?v' 绿色表示一切正常, 黄色表示所有的数据可用但是部分副本还没有分配,红色表示部分数据因为某些原因不可用. 2.通过如下语句,我们可以获取集群的节点列表: curl 'localhost:9200/_cat/nodes?v' 3.通过如下语句,列出所有索引: curl 'localhost:9200/_cat/indices?v' 返回结果: 4.创建索引

elasticsearch 复合查询

常用查询 固定分数查询 127.0.0.1/_search(全文搜索) { "query":{ "match"{ "title":"elashsearch" //查询标题含有elashsearch的字段 } } } 用固定分数查询 { "query":{ "constant_score"{ //关键词 "filter":{ //filter下写查询的语法 "

Elastic Search之布尔查询

前言 布尔查询是最常见的组合查询,根据子查询的规则,只有当文档满足所有子查询条件时,Elastic Search 引擎才会将结果返回.布尔查询支持的子查询条件共4种: must(and) should(or) must_not(not) filter 准备数据 PUT zhifou/doc/1 { "name":"顾老二", "age":30, "from":"gu", "desc":&

ElasticSearch基本查询

词条查询 这是一个简单查询.它仅 匹配给定字段中包含该词条的稳定,且是2未经分析的确切的词条. { "query" :{ "term":{ "title":"crime" } } } 多词条查询 匹配内容中包含某些词条的文档. { "query" :{ "terms::{ "tags":["novel","book"], "mi

基于百度地图SDK和Elasticsearch GEO查询的地理围栏分析系统(1)

本文描述了一个系统,功能是评价和抽象地理围栏(Geo-fencing),以及监控和分析核心地理围栏中业务的表现. 技术栈:Spring-JQuery-百度地图WEB SDK 存储:Hive-Elasticsearch-MySQL-Redis 什么是地理围栏? LBS系统中,地理围栏指的是虚拟边界围成的部分. tips:这只是一个demo,支撑实习生的本科毕设,不代表生产环境,而且数据已经做了脱密处理,为了安全还是隐去了所有数据. 功能描述 1.地理围栏的圈选 (1)热力图 热力图展示的是,北京市

四十五 Python分布式爬虫打造搜索引擎Scrapy精讲—elasticsearch(搜索引擎)的bool组合查询

bool查询说明 filter:[],字段的过滤,不参与打分must:[],如果有多个查询,都必须满足[并且]should:[],如果有多个查询,满足一个或者多个都匹配[或者]must_not:[],相反查询词一个都不满足的就匹配[取反,非] # bool查询 # 老版本的filtered已经被bool替换 #用 bool 包括 must should must_not filter 来完成 #格式如下: #bool:{ # "filter":[], 字段的过滤,不参与打分 # &qu

Elasticsearch (DSL 布尔查询 过滤器 排序 高亮显示

es 可以组合查询 must:查询必须匹配搜素条件 比如数据库中的and should :查询 至少 满足条件 比如数据库中的or must_not: 不匹配查询条件,一个都不要满足 must must_not should 至少要包含一个条件 复合查询 原文地址:https://www.cnblogs.com/loujiang/p/12701596.html