ElasticSearch:组合查询或复合查询
Bool查询
允许在单独的查询中组合任意数量的查询,指定的查询语句表名哪些部分是必须匹配(must)、应该匹配(should)或不能匹配(must_not)
Bool过滤器
和查询功能一致,但是同等情况下,推荐使用过滤器
Range查询和过滤
用于查询介于一定范围之内的值,适用于数字,日期,字符串。
| 参数 | 含义 |
| :----: | :----: |
|gt | 搜索大于某值的字段,不包括该值本身
|gte | 搜索大于某值的字段,包括该值本身
|lt | 搜索小于某值的字段,不包括该值本身
|lte | 搜索小于某值的字段,包括该值本身
使用range查询时,请仔细考虑一下过滤器是否为更好的选择。由于在查询范围之中的文档是二元的匹配(“是的,文档在范围之中”或者“不是,文档不在范围之中”),
range
查询不必是查询。为了获得更好的性能,它应该是过滤器。如果不确定使用查询还是过滤器,请使用过滤器。在99%的用例中,使用range过滤器是正确的选择。
Prefix查询与过滤
和term查询类似,prefix 查询和过滤器允许你根据给定的前缀来搜索词条,这里前缀在搜索之前是没有经过分析的。例如,为了在索引中搜索以“liber” 开头的全部活动。
wildcard查询
字面意思,通配符查询,可使用 *,?来匹配任意字符。
exists过滤器
正如其名,exists 过滤器允许你过滤文档,只查找那些在特定字段有值的文档,无论其值是多少。exists 过滤器看上去是这样的

missing 过滤器
-----------
missing过滤器让你可以搜索字段里没有值,或者是映射时指定的默认值的文档(也叫作null值,即映射里的nul1_ value)。 为了搜索缺失reviews字段的文档,可以使用下面这样的过滤器:


常用案例中使用哪些类型的查询
|用例 | 使用的查询类型|
| :----: | :----: |
|你想从类似Google的界面接受用户的输入,然后根据这些输入搜索文档 |如果想支持+/-或者在特定字段中搜索,就使用match查询simple query_ string查询|
|你想将输入作为词组并搜索包含这个词组的文档,词组中的单词间也许包含一些间隔(slop)| 要查找和用户搜索相似的词组,使用match phrase查询,并设置一定量的slop|
|你想在not_ analyzed字段中搜索单个的关键词,并完全清楚这个词应该是如何出现的| 使用term查询,因为查询的词条不会被分析
你希望组合许多不同的搜索请求或者不同类型的搜索,创建一个单独的搜索来处理它们 使用bool查询,将任意数量的子查询组合到一个单独的查询|
|你希望在某个文档中的多个字段搜索特定的单词| 使用multi_ match查询,它和match查询的表现类似,不过是在多个字段上搜索|
|你希望通过一次搜索返回所有的文档 |使用match_all查询,在---次搜索中返回全部文档|
|你希望在字段中搜索一定取值范围内的值| 使用range查询,搜索取值在一定范围内的文档|
|你希望在字段中搜索以特定字符串开头的取值| 使用prefix查询,搜索以给定字符串开头的词条|
|你希望根据用户已经输入的内容,提供单个关键词的自动完成功能| 使用prefix查询,发送用户已经输入的内容,然后获取以此文本开头的匹配项|
|你希望搜索特定字段没有取值的所有文档| 使用missing过滤器过滤出缺失某些字段的文档
ElasticSearch:组合查询或复合查询的更多相关文章
- Es学习第九课, 聚合查询和复合查询
ES除了实现前几课的基本查询,也可以实现类似关系型数据库的聚合查询,如平均值sum.最小值min.最大值max等等 我们就用上一课的数据作为参考来举例 聚合查询 sum聚合 sum是一个求累加值的聚合 ...
- Elasticsearch(7) --- 复合查询
Elasticsearch(7) ---复合查询 复合查询有:bool query(布尔查询).boosting query(提高查询).constant_score(固定分数查询).dis_max( ...
- elasticsearch组合多条件查询实现restful api以及java代码实现
原文:http://blog.java1234.com/blog/articles/372.html elasticsearch组合多条件查询实现restful api以及java代码实现 实际开发中 ...
- Python Elasticsearch api,组合过滤器,term过滤器,正则查询 ,match查询,获取最近一小时的数据
Python Elasticsearch api 描述:ElasticSearch是一个基于Lucene的搜索服务器.它提供了一个分布式多用户能力的全文搜索引擎,基于RESTful web接口.下 ...
- Elasticsearch 复合查询——多字符串多字段查询
前言 有时我们在搜索电影的时候,包含了多个条件,比如主演是周星驰,打分8分以上,上映时间是1990年~2001年的,那么Elasticsearch又该如何帮我们做查询呢?这里我们可以用 bool 查询 ...
- Elasticsearch实现复合查询,高亮结果等技巧
一.Es的配置 实现es的全文检索功能的第一步,首先从与es进行连接开始,这里我使用的是es的5.x java api语法. public TransportClient esClient() thr ...
- elasticsearch 复合查询
常用查询 固定分数查询 127.0.0.1/_search(全文搜索) { "query":{ "match"{ "title":" ...
- Elasticsearch结构化搜索与查询
Elasticsearch 的功能之一就是搜索,搜索主要分为两种类型,结构化搜索和全文搜索.结构化搜索是指有关查询那些具有内在结构数据的过程.比如日期.时间和数字都是结构化的:它们有精确的格式,我们可 ...
- 014-elasticsearch5.4.3【五】-搜索API【三】复合查询boolQuery、constantScoreQuery、disMaxQuery
一.概述 复合查询包装其他复合或叶子查询,以组合其结果和分数,更改其行为,或从查询切换到筛选器上下文. 1.1.constantScoreQuery 包含另一个查询但在过滤器上下文中执行的查询.所有匹 ...
随机推荐
- CGI,WSGI区别
WSGI 参考link:https://jingtyu.gitbooks.io/learning-openstack/content/351-usgi.html(本人的gitbook) 个人理解: w ...
- Intellij IDEA 打开文件tab数量限制的调整
最近在阅读一个开源项目,发现IDEA对同时打开的文件TAB有限制,最多只能打开10个文件Tab,再多开就会把原来的Tab关闭了. 找了半天,在菜单中找到了调整方法,以Mac为例,调整路径为 “Inte ...
- 基础算法和数据结构高频题 II
DFS的两种理解方式:1. 按照实际执行顺序模拟 (适合枚举型DFS,下节课内容)2. 按照DFS的定义宏观理解 (适合分治型DFS,本节课内容) 1 Convert BST to Greater T ...
- CDN绕过姿势小结
公司的各业务主站都挂了CDN,总结一波CDN绕过技巧. 什么是CDN CDN的全称是Content Delivery Network,即内容分发网络. 其基本思路是尽可能避开互联网上有可能影响数据传输 ...
- hdoj 4706 Children's Day
题目意思就是用a-z组成一个N,然后到z后又跳回a,输出宽从3到10的N. #include <stdio.h> #include <string.h> char s[14][ ...
- 曹工杂谈:Linux服务器上,Spring Boot 原地修改 jar 包配置文件/替换class文件,免去重复上传的麻烦
一.前言 相信很多同学有这样的需求,现在很多公司都有多地的研发中心,经常需要跨地区部署,比如,博主人在成都,但是服务器是北京的.一般城市间网络都不怎么好,上传一个几十兆的jar包那是真的慢,别说现在微 ...
- vue前后分离项目部署(不同端口号,nginx反向代理解决跨域问题)
#user nobody; worker_processes 1; #error_log logs/error.log; #error_log logs/error.log notice; #erro ...
- Java几种常见的排序算法
一.所谓排序,就是使一串记录,按照其中的某个或某些关键字的大小,递增或递减的排列起来的操作.排序算法,就是如何使得记录按照要求排列的方法.排序算法在很多领域得到相当地重视,尤其是在大量数据的处理方面. ...
- 夯实Java基础(六)——包装类
1.包装类简介 我们都知道Java是面向对象编程语言,包含了8种基本数据类型,但是这8种基本数据类型并不支持面向对象的特征,它们既不是类,也不能调用方法.这在实际使用时存在很多的不便,比如int类型需 ...
- 49.Qt-网络编程之QTCPSocket和QTCPServer(实现简易网络调试助手)
在上章 48.QT-网络通信讲解1,我们学习了网络通信基础后,本章便来实战一篇.源码正在上传中,等下贴地址. PS:支持客户端和服务器,提供源码,并且服务器支持多客户端连入,并且可以指定与个别客户端发 ...