2014-10-16 82 views
2

是否可以查询solr usign弹簧数据来获得一个字段的平均值/总和等? 我试图做方面(但只有计数可用)。Spring-Data-Solr聚合函数

我发现有可用的统计组件与solr。 添加查询一些参数,如stats.field或stats.facet应该有所帮助。

是否有可能使用spring-data-solr获得这个?

回答

2

这还没有在spring-data-solr上实现。新的功能要求做here,同时可以使用弹簧数据的Solr SolrOperations实现与一个回调,它允许你直接使用底层SolrServer如下执行这样的操作:从Spring数据 -

Map<String, FieldStatsInfo> response = template.execute(new SolrCallback<Map<String, FieldStatsInfo>>() { 

    @Override 
    public Map<String, FieldStatsInfo> doInSolr(SolrServer solrServer) throws SolrServerException, IOException { 
     SolrQuery params = new SolrQuery("*:*"); 
     params.add(StatsParams.STATS, "true"); 
     params.add(StatsParams.STATS_FIELD, "price"); 
     QueryResponse query = solrServer.query(params); 
     return query.getFieldStatsInfo(); 
    } 

}); 

System.out.println("Price sum....: " + response.get("price").getSum()); 
System.out.println("Price mean...: " + response.get("price").getMean()); 
System.out.println("Price min....: " + response.get("price").getMin()); 
System.out.println("Price max....: " + response.get("price").getMax()); 

Solr版本1.4 M1您可以使用StatsOptions执行此操作,如下所示:

SimpleQuery statsQuery; 
... 
statsQuery.setStatsOptions(new StatsOptions().addField("price")); 
...  
StatsPage<Product> statsPage = solrTemplate.queryForStatsPage(statsQuery, Product.class); 

FieldStatsResult priceStatResult = statResultPage.getFieldStatsResult("price"); 
Object max = priceStatResult.getMax(); 
Long missing = priceStatResult.getMissing();