#子条件查询: 特定字段查询 所指特定值(子条件查询又分为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类型字段模糊查询)