elastic search query & filter & query_string

 

 

 

 一、基本概念

1、query时,如何指定返回哪些字段

希望返回name和date字段

 

希望返回以location.*为前缀的字段以及date字段;不希望返回location.geolocation字段。

 

2、如何对检索到的结果进行排序

 

3、同时使用多种限制进行查询

 

 

4、response中各个字段分别是什么意思

 

5、在某个字段中查找含有指定字段的记录

 

6、query和filter有何区别?

query是模糊匹配,filter是yes/no匹配。正因如此,filter会比query运行起来快很多。

7、如何使用filter来约束query的搜索结果

二、几种常用的搜索方式

1、match_all 搜索

match_all顾名思义就是会返回所有指定index下的document。一般来说,它会配合filter进行使用,用来提取满足某些条件的document。例如:

其中,get-together为index名。

2、query_string 搜索

最简单的query_string的用法为:

 

 默认情况下,query_string会检索 _all 字段,这个字段会将document内所有的字段打包在一起。若想要指定query_string搜索的字段,那么可以在query语法内,使用诸如"description:nosql"或设置默认字段 default_field: description,例如:

如此,由于query语法内未指定搜索的字段,那么query_string将在default_field指定的description字段下搜索含有nosql的document。

3、AND OR 及 exclude 操作

例如,要搜索名字中含有nosql字样,但description中不含有mongodb字样的document

4、如何在指定时间范围内进行搜索

 

5、在哪能查到query_string的所有语法

http://www.lucenetutorial.com/lucene-query-syntax.html

query_string虽然提供了丰富而强大的语法,但是若使用过于复杂的语法会导致阅读难度陡增。例如下面这段query_string:

 

posted @ 2017-10-20 15:10  elar  阅读(875)  评论(0编辑  收藏  举报