分页查询只需要传入每页显示多少条记录,当前是第几页就可以了。
当然是对搜索返回的结果进行分页,并不是对搜索结果的总数量进行分页,因为我们搜索的时候都是返回前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 ); } |