您的位置:首页 > 其它

Lucene分页-----SearcherAfter

2016-12-19 14:07 337 查看
1 /**
2      * 分页,SearcherAfter
3      * @param query
4      * @param pageIndex
5      * @param pageSize
6      */
7     public void searchPageByAfter(String query,int pageIndex,int pageSize){
8         try {
9             IndexSearcher indexSearcher = getSearcher();
10             QueryParser parser = new QueryParser("content", new StandardAnalyzer());
11             Query q = parser.parse(query);
12             //获取上一页的最后一个元素
13             ScoreDoc lastScoreDoc = getLastScoreDoc(pageIndex, pageSize, q, indexSearcher);
14             //通过最后一个元素搜索下页的pageSize个元素
15             TopDocs topDocs = indexSearcher.searchAfter(lastScoreDoc,q,pageSize);
16             System.out.println("共:"+topDocs.totalHits);
17             for (ScoreDoc item : topDocs.scoreDocs) {
18                 Document doc = indexSearcher.doc(item.doc);
19                 System.out.println("名字:" + doc.get("name") + ",邮箱:" + doc.get("email") + ",id:" + doc.get("id"));
20             }
21         } catch (Exception e) {
22             // TODO: handle exception
23             e.printStackTrace();
24         }finally{
25             try {
26                 directory.close();
27             } catch (IOException e) {
28                 // TODO Auto-generated catch block
29                 e.printStackTrace();
30             }
31         }
32     }


测试:

@Test
public void searchPageByAfter(){
SearchUtil util = new SearchUtil();
util.searchPageByAfter("like",1,3);
}




内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: