- 搜索的代碼
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條搜索結果