lucene4.7 过滤Filter(六)
关于过滤方面的知识,也就是Filter,如果了解Solr的朋友们,肯定都会知道Solr里面fq这个参数,这个参数的作用其实就是lucene里面的过滤,对一些q参数查询的结果集,做过滤或者限制返回一些我们需要的内容,可以理解成缩小搜索空间的一种策略。

//使用缓存过滤
最后我来看下,如何继承Filter基类,来定制我们自己的filter,自定义的Filter,虽然某些时候,功能很强大灵活,但是有几个缺点,我们的了解1,保证是内容不重复的字段,例如主键,如果重复,默认返回第一个作为结果集显示2,保证不能被分词的内容,如果是分词的字段,则可能会出现一些不正确的结果。
Please read full article from lucene4.7 过滤Filter(六)
关于过滤方面的知识,也就是Filter,如果了解Solr的朋友们,肯定都会知道Solr里面fq这个参数,这个参数的作用其实就是lucene里面的过滤,对一些q参数查询的结果集,做过滤或者限制返回一些我们需要的内容,可以理解成缩小搜索空间的一种策略。
//使用过滤器 最后一个为true时包含边界部分,为false时不包含边界部分//倒数第二个为true时,包含查询边界,为false时不包含TermRangeFilter filter=new TermRangeFilter("ename", new BytesRef("h"), new BytesRef("n"), true, true);TopDocs topDocs=searcher.search(new MatchAllDocsQuery(),filter,10000);//默认无排序方式 NumericRangeFilter<Double> filter=NumericRangeFilter.newDoubleRange("price", 10D, 40D, true, false); TopDocs topDocs=searcher.search(new MatchAllDocsQuery(),filter,10000);//默认无排序方式//使用缓存过滤
Filter filter=FieldCacheRangeFilter.newDoubleRange("price", 20D, 50D, true, true); TopDocs topDocs=searcher.search(new MatchAllDocsQuery(),filter,10000);//默认无排序方式// 缓存域过滤特定的类别 Filter filter=new FieldCacheTermsFilter("type", new String[]{"技术","社会"}); TopDocs topDocs=searcher.search(new MatchAllDocsQuery(),filter,10000);//默认无排序方式//使用QueryWrapperFilter类包装一个Query QueryWrapperFilter filter=new QueryWrapperFilter(new TermQuery(new Term("type", "技术"))); TopDocs topDocs=searcher.search(new MatchAllDocsQuery(),filter,10000);//默认无排序方式public class MyCustomFilter extends Filter{ public MyCustomFilter() { // TODO Auto-generated constructor stub } private String[] terms;//限制返回的数据字典 public MyCustomFilter(String ...terms) { // TODO Auto-generated constructor stub this.terms=terms; } @Override public DocIdSet getDocIdSet(AtomicReaderContext arg0, Bits arg1) throws IOException { FixedBitSet bits=new FixedBitSet(arg0.reader().maxDoc()) ;//获取没有所有的docid包括未删除的 int base=arg0.docBase;//段的相对基数,保证多个段时相对位置正确 //int limit=base+arg0.reader().maxDoc();//计算最大限制值 for(String s:terms){ DocsEnum doc=arg0.reader().termDocsEnum(new Term("id", s));//必须是唯一的不重复 //保证是单个不重复的term,如果重复的话,默认会取第一个作为返回结果集,分词后的term也不适用自定义term if(doc.nextDoc()!=-1){ bits.set(doc.docID());//对付符合条件约束的docid循环添加到bits里面 } } return bits; }}MyCustomFilter filter=new MyCustomFilter("3","5","2");//随意指定1之多个需要过滤的项 TopDocs topDocs=searcher.search(new MatchAllDocsQuery(),filter,10000);Please read full article from lucene4.7 过滤Filter(六)
No comments:
Post a Comment