首页 > 代码库 > Elasticsearch的javaAPI之Query DSL-filters

Elasticsearch的javaAPI之Query DSL-filters

Elasticsearch的javaAPI之Query DSL-filters

REST query dsl一样,elasticsearch提供了一个完整的Java query dsl。 工厂过滤器建造者是FilterBuilders 一旦准备好您的查询,就可以使用query api。

如何构建查询?使用FilterBuilders,导入它们在你的类:

import org.elasticsearch.index.query.FilterBuilders.*;


请注意,在FilterBuilder对象上可以轻松地打印(又名调试) 查询生成的JSON,用 toString()方法 





下面选取了几个常用的filer:

andfilter

FilterBuilders.andFilter(


    FilterBuilders.rangeFilter("postDate").from("2010-03-01").to("2010-04-01"),


    FilterBuilders.prefixFilter("name.second", "ba")


    );


注意,您可以缓存结果,用AndFilterBuilder#cache(boolean) method方法。

 

bool filter

FilterBuilders.boolFilter()


    .must(FilterBuilders.termFilter("tag", "wow"))


    .mustNot(FilterBuilders.rangeFilter("age").from("10").to("20"))


    .should(FilterBuilders.termFilter("tag", "sometag"))


    .should(FilterBuilders.termFilter("tag", "sometagtag"));


用 BoolFilterBuilder#cache(boolean) method缓存结果



exists filter

FilterBuilders.existsFilter("user");




matchall filter

FilterBuilders.matchAllFilter();




notfilter

FilterBuilders.notFilter(


    FilterBuilders.rangeFilter("price").from("1").to("2"));




or filter

FilterBuilders.orFilter(


        FilterBuilders.termFilter("name.second", "banon"),


        FilterBuilders.termFilter("name.nick", "kimchy")


    );


OrFilterBuilder#cache(boolean) method缓存结果



query filter

FilterBuilders.queryFilter(


        QueryBuilders.queryString("this AND that OR thus")


    );


QueryFilterBuilder#cache(boolean) method缓存结果



range filter

FilterBuilders.rangeFilter("age")


    .from("10")


    .to("20")


    .includeLower(true)


    .includeUpper(false);




// A simplified form using gte, gt, lt or lte


FilterBuilders.rangeFilter("age")


    .gte("10")


    .lt("20");


RangeFilterBuilder#cache(boolean)method 缓存结果

t

term filter

FilterBuilders.termFilter("user", "kimchy");

你可以使用TermFilterBuilder#cache(boolean) method来不适用缓存.

t

terms filter

FilterBuilders.termsFilter("user", "kimchy", "elasticsearch")


    .execution("plain");     // Optional, can be also "bool", "and" or "or"


                            // or "bool_nocache", "and_nocache" or "or_nocache"


你可以不使用缓存,用TermsFilterBuilder#cache(boolean)method



cache

默认情况下,一些过滤器缓存,一些不缓存缓存。 你可以有一个好的控制使用cache(boolean)方法时存在。 例如:

FilterBuilder filter=FilterBuilders.andFilter(


        FilterBuilders.rangeFilter("postDate").from("2010-03-01").to("2010-04-01"),


        FilterBuilders.prefixFilter("name.second", "ba")


        )


    .cache(true);


 


Elasticsearch的javaAPI之Query DSL-filters