内容简介:在上一讲我们可以发现,对于multi-value的搜索方式,实现起来可以有多种方式。这里就说明一下,实现的方式虽然很多,但是elasticsearch在查询的时候底层都会转换为bool + term的形式使用类似上面的match query进行多值搜索的时候,elasticsearch会在底层自动将这个match query转换为bool的语法转换为:
在上一讲我们可以发现,对于multi-value的搜索方式,实现起来可以有多种方式。这里就说明一下,实现的方式虽然很多,但是elasticsearch在查询的时候底层都会转换为bool + term的形式
1、普通的match如何转换为term+should
{ "match": { "title": "java elasticsearch" } }
使用类似上面的match query进行多值搜索的时候,elasticsearch会在底层自动将这个match query转换为bool的语法
{ "bool": { "should": [ { "term": { "title": "java" } }, { "term: { "title": "elasticsearch" } } ] } }
2、and match 如何转换为term+must
{ "match": { "title": { "query": "java elasticsearch", "operator": "and" } } }
转换为:
{ "bool": { "must": [ { "term": { "title": "java" } }, { "term": { "title": "elasticsearch" } } ] } }
3、minimum_should_match如何转换
{ "match": { "title": { "query": "java elasticsearch spark hadoop", "minimum_should_match": 3 } } }
转换为:
{ "bool": { "should": [ { "term": { "title": "java" } }, { "term": { "title": "elasticsearch" } }, { "term": { "title": "spark" } }, { "term": { "title": "hadoop" } } ], "minimum_should_match": 3 } }
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- Elasticsearch GatewayModule 底层原理及参数优化深入剖析-搜索系统线上实战
- avue 1.5.2 优化大量底层代码,crud 和 form 底层公用
- Synchronized 关键字使用、底层原理、JDK1.6 之后的底层优化以及 和ReenTrantLock 的对比
- Docker 底层原理浅析
- NSDictionary底层实现原理
- PHP 数组底层实现
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。