Lucene自定义过滤
1. Query与Filter同异
Lucene中查询(Query)和过滤(Filter)有相似之处,查询能处理的过滤也可以完成。不同之处在于查询时带有评分操作,返回的结果集有相关性评分,而过滤返回的结果集没有相关性评分,即返回结果是无排序的。
2. Filter类结构图
CachingWrapperFilter、FileCacheRangeFilter和FileCacheTermFilter是附带缓存的过滤器.
3. 过滤器基本使用
(1) TermRangeFilter
特定项范围过滤器,如“a-m”或者“o-z".
TermRangeFilter filter = new TermRangeFilter(field,new BytesRef("h"),new BytesRef("h"),true,true);
TopDocs docs = searcher.search(new MatchAllDocsQuery(),filter,10);
(2)NumericRangeFilter
数值范围过滤器
NumericRangeFilter<Double> filter=NumericRangeFilter.newDoubleRange(field, 10D, 40D, true, false);
TopDocs topDocs=searcher.search(new MatchAllDocsQuery(),filter,10);
(3)
FieldCacheRangeFilter
域缓存范围过滤器
Filter filter=FieldCacheRangeFilter.newDoubleRange(field, 20D, 50D, true, true);
TopDocs topDocs=searcher.search(new MatchAllDocsQuery(),filter,10);
(4)
FieldCacheTermsFilter
域缓存过滤特定项过滤器
Filter filter=new FieldCacheTermsFilter(field, new String[]{"技术","社会"});
TopDocs topDocs=searcher.search(new MatchAllDocsQuery(),filter,10);
(5)
QueryWrapperFilter
使用 QueryWrapperFilter类包装一个query
QueryWrapperFilter filter=new QueryWrapperFilter(new TermQuery(new Term(field, "技术")));
TopDocs topDocs=searcher.search(new MatchAllDocsQuery(),filter,10);
4.自定义过滤器
自定义过滤器MyCustomFilter,继承Filter类即可。参考:https://www.jianshu.com/p/92723757f4a7