`
Java_大猫
  • 浏览: 173557 次
  • 性别: Icon_minigender_1
  • 来自: 大连
社区版块
存档分类
最新评论

基于solrJ 查询 显示 分页,高亮等处理

 
阅读更多
直接贴代码:

 Map<String, Object> map = new HashMap<String, Object>();
        AjaxResultModel arm = new AjaxResultModel();
        try {
            List<String> searchTypeList = new ArrayList<String>();

            SolrServer server = new HttpSolrServer(SearchUtils.SOLR_HTTP_SERVER_URL);
            SolrQuery query = new SolrQuery(SearchConstants.SEARCH_KEY_ALL + keyWord);

            HightLightUtils.getFilterQuery(prece, news, book, boat, knowledge, operate, selectType, query);

            PagingInfo page = HightLightUtils.setPageAndHightLight(curPage, pageSize, keyWord, query);

            List<SolrInforModel> list = new ArrayList<SolrInforModel>();

            QueryResponse qResponse = server.query(query);

            String lastWord = SolrDocUtils.checkSpellKey(query, qResponse);

            SolrDocumentList docs = qResponse.getResults();

            FacetField facetField = qResponse.getFacetField("root_info_type_id");
            List<Count> counts = null;

            if (facetField != null) {
                counts = facetField.getValues();
            }
            for (SolrDocument doc : docs) {
                SolrDocUtils.getSolrDocument(list, qResponse, doc);
            }

            SpringModelExtraUtils.ajaxMapModel(pageSize, map, searchTypeList, page, list, lastWord, docs, counts);
            arm.setData(map);
            arm.setStatus(AjaxResultModel.SUCCESS);
        } catch (Exception e) {
            arm.setStatus(AjaxResultModel.FAIL);

            logger.error(Thread.currentThread().getStackTrace()[1].getClass(),
                    Thread.currentThread().getStackTrace()[1].getMethodName(), e.getMessage());
        }
        JsonUtils.objToJson(arm, response);
    }

 public static String getFilterQuery( String news, String book, String boat, String knowledge,
            String selectType, SolrQuery query) {
        String fq = "";

  
        if (StringUtils.isNotBlank(news)) {
            fq += news + ",";
        }
        if (StringUtils.isNotBlank(book)) {
            fq += book + ",";
        }
        if (StringUtils.isNotBlank(boat)) {
            fq += boat + ",";
        }
        if (StringUtils.isNotBlank(knowledge)) {
            fq += knowledge + ",";
        }
        if (StringUtils.isNotBlank(selectType) && !"all".equals(selectType)) {
            fq += selectType + ",";
        }
        if (StringUtils.isNotBlank(fq)) {
            fq = fq.substring(0, fq.lastIndexOf(","));
            query.addFilterQuery(SearchConstants.INFO_TYPE_KEY + fq);
        }
        return fq;
    }


HightLightUtils
   /**
     * 设置分页高亮
     * 
     * @param curPage
     * @param pageSize
     * @param keyWord
     * @param query
     * @return
     */
    public static PagingInfo setPageAndHightLight(Integer curPage, Integer pageSize, String keyWord, SolrQuery query) {
        PagingInfo page = new PagingInfo(pageSize, curPage);
        query.setStart((page.getCurrentPage() - 1) * page.getPageSize());
        query.setRows(pageSize);
        query.setHighlight(true);
        query.setParam("hl.fl", "info_title,info_content");
        query.setHighlightSimplePre("<font color=\'red\'>");

        query.setHighlightSimplePost("</font>");
        query.setHighlightFragsize(200);
        query.set("qt", "/spell");
        query.set("spellcheck", "on");
        query.set("spellcheck.q", keyWord);
        query.set("spellcheck.collate", "true");
        query.set("spellcheck.dictionary", "file");
        query.set("spellcheck.build", "true");
        query.set("facet", "on");
        query.set("facet.field", "root_info_type_id");
        return page;
    }




//纠错拼写
    public static String checkSpellKey(SolrQuery query, QueryResponse spellRespose) throws SolrServerException {
        String lastWord = "";
        SpellCheckResponse spellCheckResponse = spellRespose.getSpellCheckResponse();
        List<Suggestion> suggestionList = spellCheckResponse.getSuggestions();

        if (suggestionList.size() > 0) {
            if (!spellCheckResponse.isCorrectlySpelled()) {
                lastWord = suggestionList.get(0).getAlternatives().toString().replace("[", "").replace("]", "");
                if (lastWord.indexOf(",") > 0) {
                    lastWord = lastWord.split(",")[0].toString();
                }
            }

            query.set("q", lastWord);
        }
        return lastWord;
    }
//文档高亮等
    public static String getSolrDocument(List<SolrInforModel> list, QueryResponse qResponse, SolrDocument doc) {
        SolrInforModel pj = new SolrInforModel();

        String id = doc.getFieldValue("id").toString();
        String solrTitle = SolrStringUtils.htmlReplace(doc.getFieldValue("info_title").toString());

        String solrType = SolrStringUtils.htmlReplace(doc.getFieldValue("info_type_name").toString());

        pj.setId(id);
        String hightTitle = qResponse.getHighlighting().get(id).get("info_title") == null ? solrTitle : SolrStringUtils
                .htmlReplace(qResponse.getHighlighting().get(id).get("info_title").toString());

        String solrContent = SolrStringUtils.htmlReplace(doc.getFieldValue("info_content").toString());
        pj.setInfoContent(qResponse.getHighlighting().get(id).get("info_content") == null ? solrContent
                : SolrStringUtils.htmlReplace(qResponse.getHighlighting().get(id).get("info_content").toString()));

        pj.setInfoTitle(hightTitle);

        pj.setInfoTypeName(solrType);
        list.add(pj);

        return solrType;
    }

分享到:
评论

相关推荐

    solr-solrj-6.1.0

    这表明Solr设计为分布式、可扩展的解决方案,适合处理大量数据的全文检索、拼写检查、高亮显示、 faceted search(分面搜索)等任务。Solrj则作为与Solr服务器通信的桥梁,简化了这些操作的实现。 Solrj的主要功能...

    商城项目的搜索功能示例代码-使用solrj.zip

    SolrJ是Apache Solr官方提供的Java客户端库,它允许开发人员方便地与Solr服务器进行交互,包括索引数据、执行查询、处理结果等操作。下面将详细介绍这个示例代码可能涉及的几个关键知识点。 1. **Apache Solr**:...

    solr-config_solrj-demo.rar_DEMO_solr_solr的j

    DEMO将展示如何构造查询请求,包括基本查询、布尔运算、范围查询、高亮显示等。同时,结果处理如排序、分页、 faceting(分类统计)等也是查询的重要组成部分。 五、分布式Solr 随着数据量的增长,单个Solr实例可能...

    solrj的使用

    SolrJ是Apache Solr官方提供的Java客户端库,主要用于与Solr服务器进行交互,包括索引数据、查询、管理Solr核心等操作。这个库极大地简化了开发人员在Java环境中与Solr通信的过程,使得我们可以方便地在应用程序中...

    Solr 查询,索引

    Solr查询与索引是Apache Solr的核心功能,它是一个基于Lucene的开源搜索引擎服务器,提供了高效、可扩展的全文检索、命中高亮、 faceted search(分面搜索)、拼写检查、动态集群等特性。在本文中,我们将深入探讨...

    solr讲解,案例分析

    3. **查询与搜索**:展示如何使用Solrj发送查询请求,解析结果,并进行结果排序、分页和高亮显示。同时,会讨论查询优化策略,如使用过滤器、缓存和查询分析器等。 4. **高级功能**:可能包括实时索引更新、分布式...

    java进阶Solr从基础到实战

    5. 高亮查询 6. Suggest查询 7. SolrJ 章节三:Solr高级(上) 1. Solr Cloud 2. 函数查询 3. 地理位置查询 4. JSON Facet 章节四:Solr高级(下) 1. 深度分页 2. Solr Join查询 3. 相关度排序 4.Solr缓存 5....

    solr实现的搜索引擎

    查询结果可以自定义排序、分页和高亮显示,提升用户体验。 6. **分布式搜索** SolrCloud模式下,Solr支持分布式搜索。多台Solr服务器通过ZooKeeper协调,形成一个分布式集群。数据分布和查询路由由ZooKeeper自动...

    solr实现京东搜索

    除了基本功能,Solr还可以实现如拼音搜索、同义词扩展、高亮显示搜索结果、相关性评分等高级特性,进一步提升用户体验。例如,通过添加拼音分析器,用户可以用汉字拼音进行搜索;利用Solr的自定义相似度函数,可以...

    使用java实现solr-7.1.0的api和solr最新支持的sql查询

    在实际应用中,你还需要考虑性能优化,如使用Solr的缓存机制、分页查询、查询过滤器(Filter Queries)等。同时,为了确保高可用性和可扩展性,可能需要在生产环境中部署分布式Solr集群,利用ZooKeeper进行集群管理...

    solr使用教程结合taotao项目的search模块1

    搜索功能可能还需要支持分页、高亮、过滤、排序等多种高级特性。 总的来说,Solr 在 TaoTao 项目中扮演了关键角色,提高了搜索效率和用户体验。理解 Solr 的核心概念、安装配置和使用方法,对于成功集成到电商项目...

    Solr 4.0 源代码实例

    2. **查询与结果处理**:展示如何构造查询语句,使用高亮、 faceting、自定义排序和分页等功能。 3. **搜索性能优化**:可能包含关于索引结构优化、查询缓存配置和硬件需求等方面的示例。 4. **分布式搜索**:在...

    Lucene全文检索框架+Solr+ElasticSearch搜索引擎(Java高级必备.ES)

    7、通过Solr后台管理界面对索引进行CRUD高亮过滤排序分页 8、通过Solrj实现索引的添加更新 9、通过Solrj实现索引的删除 10、索引的检索_过滤_高亮等操作 11、项目实战应用 12、Solr知识点总结 1、熟练掌握...

    全文搜索引擎Solr与ElasticSearch入门至集群及项目实战(Solr+ES)

    8、通过Solr后台管理界面对索引进行CRUD高亮过滤排序分页 9、通过Solrj实现索引的添加更新 10、通过Solrj实现索引的删除 11、索引的检索_过滤_高亮等操作 12、项目实战应用 13、Solr知识点总结 14、ElasticSearch...

Global site tag (gtag.js) - Google Analytics