1、跨度查询SpanQuery5个子类
SpanQuery类型描述
SpanTermQuery和其他跨度查询结合使用,单独使用相当于TermQuery
SpanFirstQuery用来匹配域中的第一个部分内的各个spans
SpanNearQuery用来匹配临近的spans
SpanNotQuery用来匹配不重叠的spans
SpanOrQueryspan查询的聚合匹配
2、测试SpanQuery
public class SpanQueryTest extends TestCase{
privateRAMDirectory directory;
privateIndexSearcher searcher;
privateIndexReader reader;
privateSpanTermQuery quick;
privateSpanTermQuery brown;
privateSpanTermQuery red;
privateSpanTermQuery fox;
privateSpanTermQuery lazy;
privateSpanTermQuerySleepy;
privateSpanTermQuery dog;
privateSpanTermQuery cat;
privateAnalyzer analyzer;
protectedvoid setUp() throws Exception{
directory=new RAMDirectory();
analyzer=newWhitespaceAnalyzer();
IndexWriter writer=new IndexWriter(directory,analyzer,true);
Document doc=new Document();
doc.add(Field.Text("f","the quck brown fox jumps over the lazydog"));
writer.addDocument(doc);
doc=new Document();
doc.add(Field.Text("f","the quick red fox jumps over the sleepycat"));
writer.addDocument(doc);
writer.close();
searcher=nweIndexSearcher(directory);
reader=IndexReader.open(directory);
quick=new SpanTermQuery(new Term("f","quick"));
brown=new SpanTermQuery(new Term("f","brown"));
red=new SpanTermQuery(new Term("f","red"));
fox=new SpanTermQuery(new Term("f","fox"));
lazy=new SpanTermQuery(new Term("f","lazy"));
sleepy=new SpanTermQuery(new Term("f","dog"));
dog=newSpanTermQuery(new Term("f","cat"));
}
privatevoid assertOnlyBrownFox(Query query) throwsException{//检查是否返回一个匹配结果
Hits hits=searcher.search(query);
assertEquals(1,hits.length());
assertEquals("wrong doc",0,hits.id(0));
}
privatevoid assertBothFoxes(Query query) throwsException{//检查是否返回2个匹配结果
Hits hits=searcher.search(query);
assertEquals(2.hits.length());
}
privatevoid assertNotMatch(Query query) throws Exception{
Hits hits=searcher.search(query);
assertEquals(0,hits.length());
}
}
3、使用SpanTermQuery类,它匹配文档的方式与TermQuery相似,但是它会记录一个文档中的相同项在文档中出现的不同位置。
SpanQuery对象一直跟踪它所匹配的结果:对于每个正进行匹配的文档,它记录下被匹配的查询文本的所有起点和终点位置(以语汇单元为一个位置)。
dumpSpans(new SpanTermQuery(newTerm("f","the")));//查询文本为the,带the的所有文档,并显示查询细节
定义一个方法dumpSpans()调用SpanQuery的一些底层API为我们查询细节。
public void dumpSpans(SpanQuery query) throws IOException{
Spansspans=query.getSpans(reader);
System.out.println(query+":");
intnumSpans=0;
Hitshits=searcher.search(query);
Float[]scores=new float[2];
for (inti0;i<hits.length();i++){
scores[hits.id(i)]=hits.score(i);
}
while(spans.next()){//spans里是单个查询文本匹配情况情况,记录着query在文档中的位置,
//next表示query在文档中的下一个位置,以及查询文本所在的文档号
numSpans++;
int id=spans.doc();
Document doc=reader.document(id);
Token[]tokens=AnaylzerUtilts.tokensFromAnalysis(analyzer,doc.get("f"));
StringBuffer buffer=new StringBuffer();
buffer.append(" ");
for (int i=0;i<tokens.length;i++){
if (i==spans.start()){
buffer.append("<");
}
buffer.append(tokens[i].termText());
if (i+1==spans.end()){
buffer.append(">");
}
buffer.append(" ");
}
buffer.append("("+scores[id]+")");
System.out.println(buffer);//输出spans的查询文本的在文档中本次出现的信息。
}
if(numspans==0){
System.out.println("no spans");//没有任何匹配
}
System.out.println();
}
第1次spans.next循环所输出:<the> quickbrown fox jumps over the lazy dog(0.18123456)
第2次spans.next循环所输出:the quick brown fox jumps over<the> lazy dog(0.18123456)
第3次spans.next循环所输出:<the> quick redfox jumps over thesleep dog(0.18123456)
第4次spans.next循环所输出:the quick red fox jumps over<the>sleepdog(0.18123456)
相关推荐
赠送jar包:lucene-analyzers-smartcn-7.7.0.jar; 赠送原API文档:lucene-analyzers-smartcn-7.7.0-javadoc.jar; 赠送源代码:lucene-analyzers-smartcn-7.7.0-sources.jar; 赠送Maven依赖信息文件:lucene-...
赠送jar包:lucene-core-7.7.0.jar; 赠送原API文档:lucene-core-7.7.0-javadoc.jar; 赠送源代码:lucene-core-7.7.0-sources.jar; 赠送Maven依赖信息文件:lucene-core-7.7.0.pom; 包含翻译后的API文档:lucene...
赠送jar包:lucene-analyzers-common-6.6.0.jar; 赠送原API文档:lucene-analyzers-common-6.6.0-javadoc.jar; 赠送源代码:lucene-analyzers-common-6.6.0-sources.jar; 赠送Maven依赖信息文件:lucene-...
这次提供的“lucene-4.7.0”压缩包包含了Lucene 4.7.0版本的所有核心组件和相关模块,是构建基于文本搜索应用的基础。 Lucene的主要特性包括: 1. **分词与索引**:Lucene使用高效的分词器将文档内容分解成独立的...
赠送jar包:lucene-suggest-6.6.0.jar; 赠送原API文档:lucene-suggest-6.6.0-javadoc.jar; 赠送源代码:lucene-suggest-6.6.0-sources.jar; 赠送Maven依赖信息文件:lucene-suggest-6.6.0.pom; 包含翻译后的API...
赠送jar包:lucene-core-7.2.1.jar; 赠送原API文档:lucene-core-7.2.1-javadoc.jar; 赠送源代码:lucene-core-7.2.1-sources.jar; 赠送Maven依赖信息文件:lucene-core-7.2.1.pom; 包含翻译后的API文档:lucene...
赠送jar包:lucene-backward-codecs-7.3.1.jar; 赠送原API文档:lucene-backward-codecs-7.3.1-javadoc.jar; 赠送源代码:lucene-backward-codecs-7.3.1-sources.jar; 赠送Maven依赖信息文件:lucene-backward-...
赠送jar包:lucene-core-6.6.0.jar; 赠送原API文档:lucene-core-6.6.0-javadoc.jar; 赠送源代码:lucene-core-6.6.0-sources.jar; 赠送Maven依赖信息文件:lucene-core-6.6.0.pom; 包含翻译后的API文档:lucene...
《Apache Lucene核心技术详解:从2.9.4到3.4.0的演变》 Apache Lucene,作为开源的全文检索库,是Java开发人员进行高效信息检索的重要工具。这个压缩包文件包含了Lucene从2.9.4版本到3.4.0版本的核心组件,让我们...
赠送jar包:lucene-memory-6.6.0.jar; 赠送原API文档:lucene-memory-6.6.0-javadoc.jar; 赠送源代码:lucene-memory-6.6.0-sources.jar; 赠送Maven依赖信息文件:lucene-memory-6.6.0.pom; 包含翻译后的API文档...
赠送jar包:lucene-suggest-7.7.0.jar; 赠送原API文档:lucene-suggest-7.7.0-javadoc.jar; 赠送源代码:lucene-suggest-7.7.0-sources.jar; 赠送Maven依赖信息文件:lucene-suggest-7.7.0.pom; 包含翻译后的API...
赠送jar包:lucene-spatial-extras-7.3.1.jar; 赠送原API文档:lucene-spatial-extras-7.3.1-javadoc.jar; 赠送源代码:lucene-spatial-extras-7.3.1-sources.jar; 赠送Maven依赖信息文件:lucene-spatial-extras...
赠送jar包:lucene-analyzers-smartcn-7.7.0.jar; 赠送原API文档:lucene-analyzers-smartcn-7.7.0-javadoc.jar; 赠送源代码:lucene-analyzers-smartcn-7.7.0-sources.jar; 赠送Maven依赖信息文件:lucene-...
赠送jar包:lucene-sandbox-7.2.1.jar; 赠送原API文档:lucene-sandbox-7.2.1-javadoc.jar; 赠送源代码:lucene-sandbox-7.2.1-sources.jar; 赠送Maven依赖信息文件:lucene-sandbox-7.2.1.pom; 包含翻译后的API...
赠送jar包:lucene-spatial-extras-7.2.1.jar; 赠送原API文档:lucene-spatial-extras-7.2.1-javadoc.jar; 赠送源代码:lucene-spatial-extras-7.2.1-sources.jar; 赠送Maven依赖信息文件:lucene-spatial-extras...
赠送jar包:lucene-spatial-6.6.0.jar; 赠送原API文档:lucene-spatial-6.6.0-javadoc.jar; 赠送源代码:lucene-spatial-6.6.0-sources.jar; 赠送Maven依赖信息文件:lucene-spatial-6.6.0.pom; 包含翻译后的API...
赠送jar包:lucene-misc-6.6.0.jar; 赠送原API文档:lucene-misc-6.6.0-javadoc.jar; 赠送源代码:lucene-misc-6.6.0-sources.jar; 赠送Maven依赖信息文件:lucene-misc-6.6.0.pom; 包含翻译后的API文档:lucene...
赠送jar包:lucene-spatial-extras-6.6.0.jar; 赠送原API文档:lucene-spatial-extras-6.6.0-javadoc.jar; 赠送源代码:lucene-spatial-extras-6.6.0-sources.jar; 赠送Maven依赖信息文件:lucene-spatial-extras...
赠送jar包:lucene-highlighter-6.6.0.jar; 赠送原API文档:lucene-highlighter-6.6.0-javadoc.jar; 赠送源代码:lucene-highlighter-6.6.0-sources.jar; 赠送Maven依赖信息文件:lucene-highlighter-6.6.0.pom;...
赠送jar包:lucene-backward-codecs-6.6.0.jar; 赠送原API文档:lucene-backward-codecs-6.6.0-javadoc.jar; 赠送源代码:lucene-backward-codecs-6.6.0-sources.jar; 赠送Maven依赖信息文件:lucene-backward-...