`

Lucene3.6的分页查询

 
阅读更多

分页查询只需要传入每页显示多少条记录,当前是第几页就可以了。

  当然是对搜索返回的结果进行分页,并不是对搜索结果的总数量进行分页,因为我们搜索的时候都是返回前n条记录。

  例如indexSearcher.search(query, 100);//只返回前100条记录



/**

     * 对搜索返回的前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);

    }
分享到:
评论

相关推荐

    lucene3.6 搜索例子

    Lucene 3.6作为一款强大的全文搜索库,提供了完整的搜索解决方案,包括高效的索引构建、灵活的查询语法和丰富的高级特性。开发者可以根据项目需求,利用Lucene构建出满足特定业务场景的搜索系统。在实践中,理解并...

    lucene3.6.jar

    这里的“lucene3.6.jar”是一个包含了Lucene 3.6版本核心功能的Java类库,它是实现全文检索的基础。 Lucene的核心特性包括索引构建、查询解析、搜索执行以及结果排序等。索引构建允许开发者将大量文本数据转换为...

    Lucene 3.6 学习笔记

    【Lucene 3.6 学习笔记】 Lucene 是一个高性能、全文本搜索库,广泛应用于各种搜索引擎的开发。本文将深入探讨Lucene 3.6版本中的关键概念、功能以及实现方法。 ### 第一章 Lucene 基础 #### 1.1 索引部分的核心...

    lucene 3.6 全文检索

    总结来说,Lucene 3.6提供了一套完整的全文检索解决方案,从文本预处理、索引构建到查询执行,再到结果展示,涵盖了搜索引擎的各个环节。熟练掌握Lucene,能够帮助你构建自己的高效搜索系统,满足各种数据检索需求。...

    lucene3.6 模仿百度自动补全

    lucene3.6 模仿百度自动补全(lucene3.6 模仿百度自动补全(lucene3.6 模仿百度自动补全(lucene3.6 模仿百度自动补全(lucene3.6 模仿百度自动补全(lucene3.6 模仿百度自动补全(lucene3.6 模仿百度自动补全

    lucene3.6实例(索引和查询)

    在网上找了实例,但是发现不能使用,只能简历索引。...lucene3.6版本,能够建立索引,能搜索。inderwriter,indexsearch. 其中包C下的helloword实例能用,其余的全是网上不能用的。直接下载 可以运行

    IKAnalyzer修复源码,Lucene3.6 Jar及使用示例

    在实际应用中,开发者可以结合Lucene3.6提供的API,构建索引和执行查询。例如,将分词后的文本作为Lucene的Document字段,建立索引;然后,使用Analyzer进行搜索查询,实现高效的全文搜索功能。 总结来说,这个修复...

    lucene 3.6

    在 Lucene 3.6 版本中,它提供了强大的文本搜索功能,适用于Java开发人员。这个版本相对稳定,对于初学者来说是一个很好的学习起点。 首先,我们来了解一下 Lucene 的核心概念: 1. **索引(Index)**:Lucene 的...

    lucene3.6工程原文件

    总结,Lucene 3.6 是一个强大的全文检索工具,通过理解它的基本概念、主要组件以及不同类型的查询,开发者可以快速构建起自己的全文搜索引擎。对于初学者而言,这个版本提供了足够的学习资源和实践机会,是深入理解...

    基于lucene3.6平台搜索工具相关包及使用说明

    在3.6版本中,Lucene提供了一套完整的搜索解决方案,包括索引构建、查询解析、结果排序等功能。本指南将深入探讨基于Lucene 3.6的搜索工具包及其使用方法。 一、Lucene 3.6核心组件 1. 分析器(Analyzer):负责对...

    lucene3.6 的源代码

    在版本3.6中,Lucene提供了一整套强大的文本搜索功能,包括索引、查询、排序、分词等。这个版本的源代码为我们提供了深入了解搜索引擎工作原理的机会。 首先,我们要明确的是,Lucene的核心在于它的索引机制。在`...

    lucene3.6的入门案例

    **Lucene 3.6 入门案例** Lucene 是一个高性能、全文本搜索库,由 Apache 软件基金会开发。它提供了完整的搜索功能,包括索引、查询、评分等,广泛应用于各种项目和产品中。在这个入门案例中,我们将深入理解如何...

    lucene 3.6 检索文件 pdf word ppt excel txt html xml

    《Lucene 3.6 全文检索技术详解与应用》 Lucene 是一个高性能、全文本搜索引擎库,由Apache软件基金会开发。在版本3.6中,它提供了强大的文件检索功能,支持对多种文件类型的搜索,包括PDF、Word、PPT、Excel、TXT...

    lucene3.6+IKAnalyzer2012FF_u1

    1. **性能提升**:Lucene 3.6通过优化索引结构和查询执行流程,显著提高了搜索速度和内存效率。 2. **多线程支持**:在索引构建和搜索过程中,引入了多线程处理,使得大规模数据处理能力得到提升。 3. **改进的文档...

    基于Lucene3.6进行全文检索的小案例

    4. **查询解析器(Query Parser)**:将用户输入的查询字符串转化为Lucene能够理解的查询对象。 5. **搜索器(Searcher)**:搜索器是实际执行查询的对象,它会查找与查询匹配的文档,并返回结果。 6. **分词器...

    lucene 3.6 索引格式总结

    本文档详细介绍了lucene3.6中的索引,以及每个部分对应于硬盘下的文件夹里的哪个文件。这个根据本人多年学术及编程经验总结的

    lucene3.6入门实例教程

    《Lucene 3.6 入门实例教程》是一份专为初学者设计的指南,旨在帮助用户快速掌握Apache Lucene 3.6版本的基本概念和应用。Lucene是一个高性能、全文检索库,广泛用于构建搜索功能强大的应用程序。这份教程通过完整的...

    第一个Lucene 3.6 (3.X) 入门实例

    【标题】:“第一个Lucene 3.6 (3.X) 入门实例” 【内容详解】 Lucene是一个高性能、全文本搜索库,由Apache软件基金会开发。它为Java开发者提供了强大的文本检索功能,广泛应用于搜索引擎、信息检索系统等场景。...

    lucene查询结果集分页代码

    在lucene搜索分页过程中,可以有两种方式 一种是将搜索结果集直接放到session中,但是假如结果集非常大,同时又存在大并发访问的时候,很可能造成服务器的内存不足,而使服务器宕机 还有一种是每次都重新进行搜索,这样...

    SSH + Lucene + 分页 + 排序 + 高亮 模拟简单新闻网站搜索引擎--dic

    SSH + Lucene + 分页 + 排序 + 高亮 模拟简单新闻网站搜索引擎--NewsWithSearch.part3 SSH + Lucene + 分页 + 排序 + 高亮 模拟简单新闻网站搜索引擎--NewsWithSearch.part2 SSH + Lucene + 分页 + 排序 + 高亮 ...

Global site tag (gtag.js) - Google Analytics