lucene之搜索索引
以下是通过lucene自带的 TermQuery来查询,即使用lucene自带的默认分词器,英文分词器进行分词。
在以后的文章中会将到中文分词等相关内容。
(以下代码用在项目中会由io问题,最好再改进一下,这里只用了测试。考虑到公司代码安全问题,这里只给出开发中的部分测试代码。)
public ArrayList<String> queryByString(String queryStr){
//上面文章中建立索引的文件目录
File indexDir = new File("D:\\luceneIndex");
FSDirectory directory;
ArrayList<String> resultList=new ArrayList<String>(10);
try {
directory=FSDirectory.open(indexDir);
IndexSearcher searcher=new IndexSearcher(directory);
if(!indexDir.exists()){
System.out.println("The Lucene index is not exist");
return null;
}
//定义搜索的基本单位。第一个参数代表了要在文档的哪一个 Field 上进行查找,第二个参数代表了要查询的关键词。
Term term = new Term("GoodsName",queryStr);
//构造查询对象。构造函数只接受一个 Term 对象
TermQuery luceneQuery = new TermQuery(term);
//搜索需要查询对象,并返回结果
TopDocs hit=searcher.search(luceneQuery, 10);
for(int i=0;i<hit.totalHits;i++){
ScoreDoc scoreDoc=hit.scoreDocs[i];
Document hitDoc=searcher.doc(scoreDoc.doc);
System.out.println("GoodsName: " + hitDoc.get("GoodsName"));
String tempStr=hitDoc.get("GoodsName");
resultList.add(tempStr);
}
} catch (IOException e) {
e.printStackTrace();
return null;
}
return resultList;
}