zoukankan      html  css  js  c++  java
  • solr QueryResponse

    最近开发,使用了solr,发现这个东东真是方便。很早就听说了,但是一直觉得配置较难,而且需要学习封装后的组件本来就要费时间,所以知道将lucene弄个熟练后才开始学习solr。

    最近写了这样的一段代码,

    ·········10········20········30········40········50········60········70········80········90········100·······110·······120·······130·······140·······150
    1. SolrDocumentList sdl = response.getResults();  
    2.         len = (int) sdl.getNumFound();  
    3.         System.out.println(len);  
    4.         for(int i = 0; i < len; i++)  
    5.         {  
    6.             SolrDocument d = sdl.get(i);  
    7.             for(Iterator<Map.Entry<String, Object>> j = d.iterator(); j.hasNext(); )  
    8.             {  
    9.                 hits.add((String)(  j.next().getValue() ) );  
    10.             }  
    11.         }  

    结果出现: index out of boundary的错误。原来getNumFound获得的是整个的查询数量。

    而sdl中仅仅包含在查询参数rows指定的文档个数。而rows默认是10,所以这里就出现越界错误了。

    改成这样就没有问题了:

    ·········10········20········30········40········50········60········70········80········90········100·······110·······120·······130·······140·······150
    1. SolrDocumentList sdl = response.getResults();  
    2.         len = (int) sdl.getNumFound();  
    3.         System.out.println(len);  
    4.         for(int i = 0; i < perPage; i++)  
    5.         {  
    6.             SolrDocument d = sdl.get(i);  
    7.             for(Iterator<Map.Entry<String, Object>> j = d.iterator(); j.hasNext(); )  
    8.             {  
    9.                 hits.add((String)(  j.next().getValue() ) );  
    10.             }  
    11.         }  

    新的项目基于solr开发,搜索更加灵活,更加方便了用户。

  • 相关阅读:
    homework2
    一件关于Bug的小事
    软件测试作业三:有关控制流图、覆盖内容
    用CSS改变select框的样式
    lab1--ideal + junit
    软件测试作业二
    记一次曾经项目中遇到的错误
    02组_现代软件工程_第04次作业——利用4象限原理分析自身CanTool项目的构成
    02组_现代软件工程_第03次作业——对于自身评价(原有水平以及长远目标分析总结)
    02组_现代软件工程_第02次作业——初谈GitHub使用详解以及设计
  • 原文地址:https://www.cnblogs.com/wycg1984/p/1567551.html
Copyright © 2011-2022 走看看