elasticsearch的高级查询

#子条件查询:      特定字段查询 所指特定值(子条件查询又分为Query context 和 Filter context)

#符合条件查询:   以一定的逻辑组合子条件查询

 

Query context :

     在查询过程中,除了判断文档是否满足查询条件外,ES还会计算一个_score来标识匹配的程度,旨在判断目标文档和查询条件匹配的有多好

Query context常用查询:

 #全文本查询 :针对文本类型数据

#字段级别查询:针对结构化数据,如数字、日期等。

先介绍文本查询的模糊匹配

这是数据库中6条数据

对title字段查询(title定为为text类型,会自动分词)

发现返回结构中有菜谱或入门的数据都返回了

如果只想准确匹配“菜谱入门”则用match_phrase

多个字段匹配查询

对author和title两个字段查询“入门”,可以看到含有“入门”的author和title都查出来了(ps:  创建索引时author是keyword只能精确查找,不会分词)

query_string查询

查询 既有"入门"又有"哈哈"的数据

匹配“入门”AND "哈哈" 或者匹配“菜谱”

指定title和author字段,查询"张三"或“杂志”

返回结果:

文本查询到此结束,下面是字段的查询

指定查询word_count是2000的数据(查询结果就不展示了)

还可以按照范围查询

查询书籍字段在2000到5000的数据有哪些

(其中 gt是大于,gte大于等于,lt小于,lte小于等于)

同理查询日期

 

**************************************************************************************************************

 

子条件查询中的Filter context :

在查询过程中,只判断该文档是否满足条件,只有Yes或No ,用来数据过滤。(而query查询还会涉及匹配程度)

 

处理结果可以看到只有word_count为2000的信息查询出来

有个地方注意,应为title是text类型,分词了,term匹配"菜谱入门",查询没结果(把term换成match会查询出来)。

*****************************************************************************************************

 

综合query和filter的符合条件查询

复合查询有: 固定分数查询、布尔查询等等。。

先看一下普通的全文匹配

返回结果将title含有“入门”的信息都返回来了,且score分数都不一样

我们可以固定分数来查询

返回结果,_score全为2

***********************************************************************************************************

布尔查询

关键词should 匹配中match条件的一种即返回数据,是或的关系

结果中有王五、入门的信息都查到了,说明是或的关系

*********************************************************

布尔查询还有一个 must关键词,即两条必须同时满足,是与的关系

返回数据如下

must还可以和filter进行组合

*******************************************************

关键词must_not , 顾名思义,是一定不能满足的条件。

返回的结果中没有author为“王五”的信息,这里就不展示搜索结果了

most_not也可以用数组格式来满足多个匹配条件(term应用在不可分割字段上,match对text类型字段模糊查询)

 

©️2020 CSDN 皮肤主题: 大白 设计师:CSDN官方博客 返回首页