- 搜索的代码
package cn.huahcao.lucene;
import org.apache.lucene.analysis.standard.StandardAnalyzer;
import org.apache.lucene.document.Document;
import org.apache.lucene.index.DirectoryReader;
import org.apache.lucene.index.IndexReader;
import org.apache.lucene.queryparser.classic.QueryParser;
import org.apache.lucene.search.IndexSearcher;
import org.apache.lucene.search.Query;
import org.apache.lucene.search.ScoreDoc;
import org.apache.lucene.search.TopDocs;
import org.apache.lucene.store.Directory;
import org.apache.lucene.store.FSDirectory;
import org.junit.Test;
import java.io.File;
public class IndexSearchTest{
private String searchField = "fileContent";
private String searchWord = "java";
@Test
public void testIndexSearch() throws Exception{
//创建分词器(创建索引和搜索时所用的分词器必须一致)
StandardAnalyzer analyzer = new StandardAnalyzer();
//指定索引和文档的目录
Directory dir = FSDirectory.open(new File("G:\\Java\\JavaEE\\09_SSM\\lucene_day01\\tmp"));
//索引和文档的读取对象
DirectoryReader indexReader = IndexReader.open(dir);
//创建索引的搜索对象
IndexSearcher indexSearcher = new IndexSearcher(indexReader);
/**
* 默认搜索域作用:如果搜索语法中指定域名从指定域中搜索,如果搜索时只写了查询关键字,则从默认搜索域中进行搜索
* 第一个参数:默认搜索域,
* 第二个参数:分词器
*/
QueryParser queryParser = new QueryParser("fileContent" , analyzer);
// Query query = queryParser.parse("apache");//从默认域搜索
Query query = queryParser.parse(searchField+":"+searchWord);//从指定域搜索
/**
* 搜索:
* 第一个参数为查询语句对象
* 第二个参数:指定显示多少条
*/
TopDocs topDocs = indexSearcher.search(query, 10);
//一共搜索到多少条记录
System.out.println("=====count======"+topDocs.totalHits);
//从搜索结果对象中获取结果集
ScoreDoc[] scoreDocs = topDocs.scoreDocs;
for (ScoreDoc scoreDoc : scoreDocs){
//获取docId
int docId = scoreDoc.doc;
//通过文档ID从硬盘中读取出对应的文档
Document document = indexReader.document(docId);
System.out.println("fileName="+document.get("fileName"));
System.out.println("fileSize="+document.get("fileSize"));
System.out.println("=====================================");
}
}
}
创建索引和搜索时所用的分词器必须一致
-
搜索结果
-
使用luke查看搜索结果
也是10条搜索结果