es dsl多条件组合查询(转)

【README】在不评分的情况下, 推荐使用filter 过滤查询,因为不评分,查询性能优于评分性能;

转:https://www.elastic.co/guide/cn/elasticsearch/guide/current/combining-queries-together.html

下面截图是我认为最有价值的地方。

【2】全文如下:

现实的查询需求从来都没有那么简单;它们需要在多个字段上查询多种多样的文本,并且根据一系列的标准来过滤。为了构建类似的高级查询,你需要一种能够将多查询组合成单一查询的查询方法。

你可以用 bool 查询来实现你的需求。这种查询将多查询组合在一起,成为用户自己想要的布尔查询。它接收以下参数:

must

文档 必须 匹配这些条件才能被包含进来。

must_not

文档 必须不 匹配这些条件才能被包含进来。

should

如果满足这些语句中的任意语句,将增加 _score ,否则,无任何影响。它们主要用于修正每个文档的相关性得分。

filter

必须 匹配,但它以不评分(查询性能优于其他评分查询)、过滤模式来进行。这些语句对评分没有贡献,只是根据过滤标准来排除或包含文档。

由于这是我们看到的第一个包含多个查询的查询,所以有必要讨论一下相关性得分是如何组合的。每一个子查询都独自地计算文档的相关性得分。一旦他们的得分被计算出来, bool 查询就将这些得分进行合并并且返回一个代表整个布尔操作的得分。

下面的查询用于查找 title 字段匹配 how to make millions 并且不被标识为 spam 的文档。那些被标识为 starred 或在2014之后的文档,将比另外那些文档拥有更高的排名。如果 两者 都满足,那么它排名将更高:

{"bool": {"must":     { "match": { "title": "how to make millions" }},"must_not": { "match": { "tag":   "spam" }},"should": [{ "match": { "tag": "starred" }},{ "range": { "date": { "gte": "2014-01-01" }}}]}
}

拷贝为 cURL在 Sense 中查看 

如果没有 must 语句,那么至少需要能够匹配其中的一条 should 语句。但,如果存在至少一条 must 语句,则对 should 语句的匹配没有要求。

增加带过滤器(filtering)的查询

如果我们不想因为文档的时间而影响得分,可以用 filter 语句来重写前面的例子:

{"bool": {"must":     { "match": { "title": "how to make millions" }},"must_not": { "match": { "tag":   "spam" }},"should": [{ "match": { "tag": "starred" }}],"filter": {"range": { "date": { "gte": "2014-01-01" }} }}
}

拷贝为 cURL在 Sense 中查看 

 

range 查询已经从 should 语句中移到 filter 语句

通过将 range 查询移到 filter 语句中,我们将它转成不评分的查询,将不再影响文档的相关性排名。由于它现在是一个不评分的查询,可以使用各种对 filter 查询有效的优化手段来提升性能。

所有查询都可以借鉴这种方式。将查询移到 bool 查询的 filter 语句中,这样它就自动的转成一个不评分的 filter 了。

如果你需要通过多个不同的标准来过滤你的文档,bool 查询本身也可以被用做不评分的查询。简单地将它放置到 filter 语句中并在内部构建布尔逻辑:

{"bool": {"must":     { "match": { "title": "how to make millions" }},"must_not": { "match": { "tag":   "spam" }},"should": [{ "match": { "tag": "starred" }}],"filter": {"bool": { "must": [{ "range": { "date": { "gte": "2014-01-01" }}},{ "range": { "price": { "lte": 29.99 }}}],"must_not": [{ "term": { "category": "ebooks" }}]}}}
}

拷贝为 cURL在 Sense 中查看 

 

将 bool 查询包裹在 filter 语句中,我们可以在过滤标准中增加布尔逻辑

通过混合布尔查询,我们可以在我们的查询请求中灵活地编写 scoring 和 filtering 查询逻辑。

constant_score 查询

尽管没有 bool 查询使用这么频繁,constant_score 查询也是你工具箱里有用的查询工具。它将一个不变的常量评分应用于所有匹配的文档。它被经常用于你只需要执行一个 filter 而没有其它查询(例如,评分查询)的情况下。

可以使用它来取代只有 filter 语句的 bool 查询。在性能上是完全相同的,但对于提高查询简洁性和清晰度有很大帮助。

{"constant_score":   {"filter": {"term": { "category": "ebooks" } }}
}

拷贝为 cURL在 Sense 中查看 

 

term 查询被放置在 constant_score 中,转成不评分的 filter。这种方式可以用来取代只有 filter 语句的 bool 查询。

 

 

 

 

 

 

 

 

 

 

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/330383.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java集合从菜鸟到大神演变

转载自 Java集合从菜鸟到大神演变 先来看一张集合概况图,这里从上到下列举了几个最经常用的集合 1、集合接口 java.util.Collection 是一个集合接口。它提供了对集合对象进行基本操作的通用接口方法。Collection接口在Java 类库中有很多具体的实现。Collection接口的…

转:Java并发编程与高并发解决方案(一)

转: https://blog.csdn.net/m0_37819279/article/details/81154126 首先介绍连接池 1:ExecutorService是Executor直接的扩展接口,也是最常用的线程池接口,我们通常见到的线程池定时任务线程池都是它的实现类。 2:Exe…

HDU1864(01背包)

Problem Descrption 现有一笔经费可以报销一定额度的发票。允许报销的发票类型包括买图书(A类)、文具(B类)、差旅(C类),要求每张发票的总额不得超过1000元,每张发票上,单…

转:并发与并行的区别

转: https://www.jianshu.com/p/b11e251d3dc7 并发:一个处理器同时处理多个任务。(concurrency) 单个cpu逻辑上同时处理多个任务;并行:多个处理器或者是多核的处理器同时处理多个不同的任务. (parallelism&#xff0…

面试必问-几种线程安全的Map解析

转载自 面试必问-几种线程安全的Map解析HashMap线程安全的吗?Java中平时用的最多的Map集合就是HashMap了,它是线程不安全的。看下面两个场景:1、当用在方法内的局部变量时,局部变量属于当前线程级别的变量,…

学习java多线程,这必须搞懂的这几个概念

转载自 学习java多线程,这必须搞懂的这几个概念,很重要。 同步和异步 同步,Synchronous,即调用方法开始,一旦调用就必须等待方法执行完返回才能继续下面的操作。 举个例子,你去银行ATM取钱,你必…

HDU1231(DP)

Problem Descrption 给定K个整数的序列{ N1, N2, ..., NK }&#xff0c;其任意连续子序列可表示为{ Ni, Ni1, ..., Nj }&#xff0c;其中 1 < i < j < K。最大连续子序列是所有连续子序列中元素和最大的一个&#xff0c; 例如给定序列{ -2, 11, -4, 13, -5, -2 }&…

8核、6核、4核、双核CPU是什么意思

转自&#xff1a; https://blog.csdn.net/he_jian1/article/details/41208915 对于初学者来说&#xff0c;CPU是什么、什么是双核、4核、6核、8核等。下面&#xff0c;就以上的问题&#xff0c;我们做出一一解答。 概念&#xff1a;CPU是什么、做什么用、一般CPU是接在哪里…

一个诡异的可见性问题

转载自 一个诡异的"可见性"问题 之前介绍过可见性的特性&#xff0c;最近做测试的时候发现了一个很诡异的问题&#xff0c;下面看看这三个例子。 test1&#xff1a; test1这个例子加了volatile&#xff0c;所以程序正确退出输出test1 end test2&#xff1a; test2这…

POJ3278(BFS)

Farmer John has been informed of the location of a fugitive cow and wants to catch her immediately. He starts at a point N (0 ≤ N ≤ 100,000) on a number line and the cow is at a point K (0 ≤ K ≤ 100,000) on the same number line. Farmer John has two mod…

转:认识cpu、核与线程

转自&#xff1a; https://www.cnblogs.com/-new/p/7234332.html 前言&#xff1a;作为一个后台开发人员&#xff0c;我想有必要了解这些基础知识。如果本文有不严谨或者疏忽的地方&#xff0c;请指正。 目录 认识cpu、核心与线程java多线程系列&#xff08;一&#xff09;之j…

java多线程中的死锁、活锁、饥饿、无锁都是什么鬼?

转载自 java多线程中的死锁、活锁、饥饿、无锁都是什么鬼&#xff1f; 死锁、活锁、饥饿是关于多线程是否活跃出现的运行阻塞障碍问题&#xff0c;如果线程出现了这三种情况&#xff0c;即线程不再活跃&#xff0c;不能再正常地执行下去了。 死锁 死锁是多线程中最差的一种情况…

HDU2159(完全背包)

Problem Descrption 最近xhd正在玩一款叫做FATE的游戏&#xff0c;为了得到极品装备&#xff0c;xhd在不停的杀怪做任务。久而久之xhd开始对杀怪产生的厌恶感&#xff0c;但又不得不通过杀怪来升完这最后一级。现在的问题是&#xff0c;xhd升掉最后一级还需n的经验值&#xff…

(转)接口幂等性

转自&#xff1a; https://blog.csdn.net/mingwulipo/article/details/91443355 1、接口调用存在的问题 现如今我们的系统大多拆分为分布式SOA&#xff0c;或者微服务&#xff0c;一套系统中包含了多个子系统服务&#xff0c;而一个子系统服务往往会去调用另一个服务&#x…

高级java必须清楚的概念:原子性、可见性、有序性

转载自 高级java必须清楚的概念&#xff1a;原子性、可见性、有序性 原子性、可见性、有序性是多线程编程中最重要的几个知识点&#xff0c;由于多线程情况复杂&#xff0c;如何让每个线程能看到正确的结果&#xff0c;这是非常重要的。 原子性 原子性是指一个线程的操作是不能…

背包问题总结

参考链接&#xff1a; http://www.cnblogs.com/fengty90/p/3768845.html http://blog.csdn.net/mu399/article/details/7722810 http://blog.csdn.net/xiaowei_cqu/article/details/8191808 http://blog.csdn.net/insistgogo/article/details/11176693 原文&#xff1a;https:…

(转)数据库可靠性/可用性、稳定性RTO/RPO

转 https://blog.csdn.net/luke_wang/article/details/78145517&#xff1b; 在灾难恢复方面&#xff0c;目前业界公认有三个目标值得努力。一是恢复时间&#xff0c;企业能忍受多长时间没有 IT&#xff0c;处于停业状态&#xff1b;二是网络多长时间能够恢复&#xff1b;三是…

HDU2059(DP)

Problem Descrption 据说在很久很久以前&#xff0c;可怜的兔子经历了人生中最大的打击——赛跑输给乌龟后&#xff0c;心中郁闷&#xff0c;发誓要报仇雪恨&#xff0c;于是躲进了杭州下沙某农业园卧薪尝胆潜心修炼&#xff0c;终于练成了绝技&#xff0c;能够毫不休息得以恒…

Java多线程之守护线程实战

转载自 Java多线程之<<守护线程>>实战定义什么是守护线程&#xff1f;与守护线程相对应的就是用户线程&#xff0c;守护线程就是守护用户线程&#xff0c;当用户线程全部执行完结束之后&#xff0c;守护线程才会跟着结束。也就是守护线程必须伴随着用户线程&#x…

转:集群和分布式的区别

转自&#xff1a; https://blog.csdn.net/shuaipu813/article/details/52083289 集群 多台服务器组成的一组计算机&#xff0c;作为一个整体存在&#xff0c;向用户提供一组网络资源&#xff0c;这些单个的服务器就是集群的节点。 集群拥有以下两个特点&#xff1a; 1. 可…