Lucene的分頁查詢
分頁查詢只需要傳入每頁顯示多少條記錄,當前是第幾頁就可以了。
當然是對搜尋返回的結果進行分頁,並不是對搜尋結果的總數量進行分頁,因為我們搜尋的時候都是返回前n條記錄。
例如indexSearcher.search(query, 100);//只返回前100條記錄
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
|
/** * 對搜尋返回的前n條結果進行分頁顯示 * @param keyWord 查詢關鍵詞 * @param pageSize 每頁顯示記錄數 * @param currentPage 當前頁
* @throws ParseException * @throws CorruptIndexException * @throws IOException */ public
void paginationQuery(String keyWord, int
pageSize, int
currentPage) throws
ParseException, CorruptIndexException, IOException {
String[] fields = { "title" , "content" };
QueryParser queryParser = new
MultiFieldQueryParser(Version.LUCENE_36,fields,analyzer);
Query query = queryParser.parse(keyWord);
IndexReader indexReader = IndexReader.open(directory);
IndexSearcher indexSearcher = new
IndexSearcher(indexReader);
//TopDocs 搜尋返回的結果
TopDocs topDocs = indexSearcher.search(query, 100 ); //只返回前100條記錄
int totalCount = topDocs.totalHits;
// 搜尋結果總數量
ScoreDoc[] scoreDocs = topDocs.scoreDocs; // 搜尋返回的結果集合
//查詢起始記錄位置
int begin = pageSize * (currentPage -
1 ) ;
//查詢終止記錄位置
int end = Math.min(begin + pageSize, scoreDocs.length);
//進行分頁查詢
for ( int
i=begin;i<end;i++) {
int docID = scoreDocs[i].doc;
Document doc = indexSearcher.doc(docID);
int id = NumericUtils.prefixCodedToInt(doc.get( "id" ));
String title = doc.get( "title" );
System.out.println( "id is : " +id);
System.out.println( "title is : " +title);
}
} @Test public
void testPaginationQuery()
throws CorruptIndexException, ParseException, IOException{
//每頁顯示5條記錄,顯示第三頁的記錄
paginationQuery( "思想" , 5 , 3 ); } |
相關文章
- Lucene查詢原理
- MySQL的分頁查詢MySql
- Oracle的分頁查詢Oracle
- Elasticsearch 分頁查詢Elasticsearch
- ssh 分頁查詢
- oracle分頁查詢Oracle
- 分庫分表後的分頁查詢
- ThinkPhp框架:分頁查詢PHP框架
- 分頁查詢優化優化
- NET 集合分頁查詢
- MySQL 多表查詢分頁MySql
- 分頁查詢重構
- Oracle分頁查詢格式Oracle
- SSH框架下的分頁查詢框架
- ssh框架中的分頁查詢框架
- 分頁查詢的排序問題排序
- hibernate 通用分頁,查詢分頁的泛型類泛型
- elasticsearch查詢之大資料集分頁查詢Elasticsearch大資料
- lucene 多欄位查詢-MultiFieldQueryParser
- indexdb實現分頁查詢Index
- AntDesignBlazor示例——分頁查詢Blazor
- MySQL分頁查詢優化MySql優化
- Oracle分頁查詢格式(十三)Oracle
- Oracle分頁查詢格式(十二)Oracle
- Oracle分頁查詢格式(十一)Oracle
- Oracle分頁查詢格式(八)Oracle
- Oracle分頁查詢格式(九)Oracle
- Oracle分頁查詢格式(十)Oracle
- oracle分頁查詢語句Oracle
- Oracle分頁查詢之order byOracle
- oracle sql分頁查詢(一)OracleSQL
- 分頁查詢初接觸
- 關於批次分頁查詢
- 批次分頁查詢問題?
- 求助~怎麼指定lucene查詢的field?
- MYSQL SQLServer分頁查詢的實現MySqlServer
- 分頁查詢的排序問題(二)排序
- MongoDB分頁查詢的方法及效能MongoDB