3

我想编写一个 FacetQuery,它可能没有任何条件,除了一个过滤条件 (fq)。以下查询是我想使用 spring-data-solr API 构建的示例。

http://localhost:8983/solr/jpevents/select?q=*:*&fq=categoryIds:(1101)&facet=true&facet.mincount=1&facet.limit=1&facet.field=primaryCategoryId

如何在 FacetQuery 中设置查询参数 (q=*:*)?

环境:我正在使用 spring-data-solr 1.0.0.RELEASE 和 Solr 4.4.0 和 Spring 3.2.4.RELEASE 编写基于 Spring MVC 的搜索 API。

4

2 回答 2

11

你可以做到这一点结合@Query@Facet

    @Facet(fields={"primaryCategoryId"}, minCount=1, limit=1)
    @Query(value="*:*", filters="categoryIds:(?0)")
    public FacetPage<JPEvents> XYZ(List<Long> categories, Pageable page);

FacetQuery使用SolrTemplate.

   FacetQuery query = new SimpleFacetQuery(new SimpleStringCriteria("*:*"))
     .setFacetOptions(new FacetOptions("primaryCategoryId")
     .setFacetMinCount(1).setFacetLimit(1));
   query.setPageRequest(pageable);
   solrTemplate.queryForFacetPage(query, JPEvents.class);
于 2013-12-18T06:01:28.090 回答
1

我做了这样的事情:

public static void main()
{
String url = "http://localhost:8983/solr/autocomplete";
    SolrServer solrServer = new HttpSolrServer(url);
    SolrQuery query = new SolrQuery();
    query.set("q", "*");
    query.addFilterQuery("name:*");
    query.setFacet(true);
    query.addFacetField("name");
    System.out.println(query);
    QueryResponse queryResponse = solrServer.query(query);
    List<FacetField> facetFields = queryResponse.getFacetFields();
    FacetField cnameMainFacetField = queryResponse.getFacetField("name");
    for (Count cnameAndCount : cnameMainFacetField.getValues()) {
        String cnameMain = cnameAndCount.getName();
        System.out.println(cnameMain);
        System.out.println(cnameAndCount.getCount());
    }

这给了我正确的分面字段计数。希望你能明白我在做什么。添加输出以便更好地理解:

q=*&fq=name%3A*&facet=true&facet.field=name
a
10
an
7
w
7
m
6
and
5
c
5
p
5
d
4
于 2014-07-07T10:35:03.377 回答