您的位置:首页 > 产品设计 > UI/UE

elastic search query & filter & query_string

2017-10-20 15:10 483 查看

一、基本概念

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:

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: