鍍金池/ 教程/ 大數(shù)據(jù)/ Lucene TermRangeQuery類
Lucene TermRangeQuery類
Lucene排序
Lucene Query類
Lucene搜索操作
Lucene TokenStream
Lucene IndexWriter類
Lucene Term類
Lucene Token
Lucene索引操作
Lucene Field選項
Lucene BooleanQuery類
Lucene StandardAnalyzer類
Lucene字段
Lucene添加文檔操作
Lucene環(huán)境設置
Lucene Searching類
Lucene StopAnalyzer類
Lucene第一個應用程序
Lucene MatchAllDocsQuery類
Lucene IndexSearcher類
Lucene索引類
Lucene更新文檔操作
Lucene教程
Lucene PrefixQuery類
Lucene Analyzer類
Lucene TopDocs類
Lucene TermQuery類
Lucene文檔
Lucene查詢編程
Lucene WildcardQuery類
Lucene WhitespaceAnalyzer
Lucene SimpleAnalyzer類
Lucene目錄
Lucene刪除文檔操作
Lucene索引過程
Lucene FuzzyQuery類
Lucene PhraseQuery類
Lucene分析

Lucene TermRangeQuery類

TermRangeQuery是在使用的范圍內的文本的詞條都被搜索。

類聲明

以下是org.apache.lucene.search.TermRangeQuery類的聲明:

public class TermRangeQuery
   extends MultiTermQuery

類的構造函數(shù)

S.N. 構造函數(shù)和說明
1 TermRangeQuery(String field, String lowerTerm, String upperTerm, boolean includeLower, boolean includeUpper)
構造一個查詢選擇的所有條款大于/等于比lowerTerm,但小于/等于比upperTerm。
2 TermRangeQuery(String field, String lowerTerm, String upperTerm, boolean includeLower, boolean includeUpper, Collator collator)
構造一個查詢選擇的所有條款大于/等于比lowerTerm,但小于/等于比upperTerm。

類方法

S.N. 方法及說明
1 boolean equals(Object obj) 
2 Collator getCollator()
返回用于確定范圍包括比較裝置,如果有的話。
3 protected FilteredTermEnum getEnum(IndexReader reader)
構造所使用的枚舉,擴大模式的詞條。
4 String getField()
此查詢返回字段名稱。
5 String getLowerTerm()
返回此范圍查詢的較低值。
6 String getUpperTerm()
返回此范圍查詢的上限值。
7 int hashCode() 
8 boolean includesLower()
返回true,如果下端點已包括。
9 boolean includesUpper()
返回true,如果上端點已包括。
10 String toString(String field)
打印這個查詢的一個用戶可讀的版本。

繼承的方法

這個類繼承了以下類方法:

  • org.apache.lucene.search.MultiTermQuery

  • org.apache.lucene.search.Query

  • java.lang.Object

使用

private void searchUsingTermRangeQuery(String searchQueryMin,
   String searchQueryMax)throws IOException, ParseException{
   searcher = new Searcher(indexDir);
   long startTime = System.currentTimeMillis();
   //create the term query object
   Query query = new TermRangeQuery(LuceneConstants.FILE_NAME, 
      searchQueryMin,searchQueryMax,true,false);
   //do the search
   TopDocs hits = searcher.search(query);
   long endTime = System.currentTimeMillis();

   System.out.println(hits.totalHits +
      " documents found. Time :" + (endTime - startTime) + "ms");
   for(ScoreDoc scoreDoc : hits.scoreDocs) {
      Document doc = searcher.getDocument(scoreDoc);
      System.out.println("File: "+ doc.get(LuceneConstants.FILE_PATH));
   }
   searcher.close();
}

應用程序示例

讓我們創(chuàng)建一個測試Lucene的應用程序中使用TermRangeQuery測試搜索。

步驟 描述
1 創(chuàng)建名稱為LuceneFirstApplication的項目在packagecom.yiibai.lucene下的Lucene用于解釋 Lucene應用程序理解搜索過程。
2 創(chuàng)建LuceneConstants.java和Searcher.java作為Lucene的解釋- 第一應用程序一章。保持其它文件不變。
3 創(chuàng)建LuceneTester.java如下所述。
4 清理和構建應用程序,以確保業(yè)務邏輯按要求工作。

LuceneConstants.java

這個類是用來提供可應用于示例應用程序中使用的各種常量。

package com.yiibai.lucene;

public class LuceneConstants {
   public static final String CONTENTS="contents";
   public static final String FILE_NAME="filename";
   public static final String FILE_PATH="filepath";
   public static final int MAX_SEARCH = 10;
}

Searcher.java

這個類用來讀取就使用Lucene庫的原始數(shù)據(jù),并搜索數(shù)據(jù)的索引。

package com.yiibai.lucene;

import java.io.File;
import java.io.IOException;

import org.apache.lucene.analysis.standard.StandardAnalyzer;
import org.apache.lucene.document.Document;
import org.apache.lucene.index.CorruptIndexException;
import org.apache.lucene上一篇:Lucene MatchAllDocsQuery類下一篇:Lucene Searching類