Lucene_demo06_几种搜索
创建searcher的过程
1、创建Directory
2、根据directory创建indexReader
3、根据indexReader创建indexSearcher
4、创建搜索的Query
5、根据searcher搜索并且返回TopDocs
6、根据TopDocs获取ScordDoc对象获取具体的Document对象
7、根据searcher和ScordDoc对象获取具体的Document对象
8、根据Document对象获取需要的值
9、关闭reader
/**
* @see 1、关键词查询
* @see 2、查询所有的文档 重点
* @see 3、范围查询
* @see 4、通配符查询 重点
* @see 5、短语查询
* @see 6、Boolean查询 重点
*/
public class QueryTest {
/**
* 关键词查询 * 因为在创建Term对象的时候,没有分词器,所以这里的字母是区分大小写的 * Term构造函数的第二个参数指的是关键词,必须存在
*/
@Test
public void testTermQuery() throws Exception {
Term term = new Term("title", "总冠军");
Query query = new TermQuery(term);
this.testSearchIndex(query);
}
/**
* 查询所有的文档
*/
@Test
public void testAllQuery() throws Exception {
Query query = new MatchAllDocsQuery();
this.testSearchIndex(query);
}
/**
* 通配符查询 说明: * 代表任意多个任意字符 ? 代表一个任意字符
*/
@Test
public void testWildCardQuery() throws Exception {
Term term = new Term("title", "*总?军");
Query query = new WildcardQuery(term);
this.testSearchIndex(query);
}
/**
* boolean查询 可以根据Occur的常量把好几个查询结合在一起
*/
@Test
public void testBooleanQuery() throws Exception {
Term term = new Term("title", "总冠军");
TermQuery termQuery = new TermQuery(term);
Term term2 = new Term("content", "2?13");
Query wildCardQuery = new WildcardQuery(term2);
BooleanQuery query = new BooleanQuery();
query.add(termQuery, Occur.SHOULD);// Occur.MUST必须有、Occur.MUST_NOT必须没有、Occur.SHOULD可以有
query.add(wildCardQuery, Occur.SHOULD);
this.testSearchIndex(query);
}
/**
* 范围查询 查询id范围在5~15间的数据
*/
@Test
public void testRangeQuery() throws Exception {
Query query = NumericRangeQuery.newLongRange("id", 5L, 15L, true, true);
this.testSearchIndex(query);
}
/**
* 所有的Term对象只能在同一个field中进行 如果两个以上大的关键词进行组合查询,得知道其中的位置(分词后的位置)
*/
@Test
public void testPharseQuery() throws Exception {
Term term = new Term("title", "NBA总冠军");
Term term2 = new Term("title", "NBA总冠军");
PhraseQuery phraseQuery = new PhraseQuery();
phraseQuery.add(term);
phraseQuery.add(term2);
this.testSearchIndex(phraseQuery);
}
// 公共输出方法
private void testSearchIndex(Query query) throws Exception {
IndexSearcher indexSearcher = new IndexSearcher(LuceneUtils.directory);
TopDocs topDocs = indexSearcher.search(query, 50);
int count = topDocs.totalHits;// 总的记录数
ScoreDoc[] scoreDocs = topDocs.scoreDocs;
List<Article> articleList = new ArrayList<Article>();
for (int i = 0; i < scoreDocs.length; i++) {
int index = scoreDocs[i].doc;
Document document = indexSearcher.doc(index);
Article article = DocumentUtils.document2Article(document);
articleList.add(article);
}
// 输入搜索出来的内容
for (Article article : articleList) {
System.out.println(article.getId());
System.out.println(article.getTitle());
System.out.println(article.getContent());
}
}
}
参考:
http://my.oschina.net/winHerson/blog/82194
分享到:
相关推荐
可用lucene demo 已经有入门级pdf学习
lucene_in_action中文版lucene_in_action中文版lucene_in_action中文版lucene_in_action中文版lucene_in_action中文版lucene_in_action中文版
大型网站站内搜索(Lucene_In_Action).pdf 大型网站站内搜索(Lucene_In_Action).pdf
这是一个基于lucene的桌面搜索引擎实例,实现了对文本的搜索
Lucene资料大全,包括:Lucene_in_Action书,尚学堂科技_张志宇_lucene.ppt等
lucene_jar包
对clucene0.9.21版本在vc6下调试demo希望对你的开发有帮助
Lucene_3.0_原理与代码分析
lucene_heritrix 搜索引擎 很好的东西来看看吧
这个压缩包包含lucene_3.6.1_API,后缀格式为chm. .;...
Lucene_in_Action 中文版
实现的的索引建立 以及全文检索等功能……
JAVA_Lucene_in_Action教程完整版
java(lucene)版的公交搜索系统,我最近在我拿工商看到的一个非常好的
一个vb.net2.0做的Lucene索引测试 vb.net的东西比较少吧,我上一个
lucene_构建一个简单的WEB搜索程序
Lucene_in_ Action java search engine.PDF 搜索引擎教程
Lucene_in_Action english版