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);


 
 


猜你喜欢

转载自blog.csdn.net/woshiyexinjie/article/details/41410231