如何使用spring-data-solr编写查询,返回特定字段的所有值的列表

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何使用spring-data-solr编写查询,返回特定字段的所有值的列表相关的知识,希望对你有一定的参考价值。

我想写一个查询,获取文档中一个字段的所有值的列表(根本没有条件)。我尝试以下代码:

@Query(fields = { "car_company_s" })
List<Car> findAllCarCompeny();

但它没有用,我得到以下错误:

Caused by: org.springframework.data.mapping.PropertyReferenceException: No property findAllCarCompeny found for type Car!

有没有办法做到这一点?

答案

你想要的是一个"Term"。基本上它返回字段的所有值。你需要solr模板,如description所述。我们使用的示例:

    @Resource
    private SolrTemplate solrTemplate;
    ...     
    query = SimpleTermsQuery.queryBuilder()
                .fields(key)
                .prefix(startsWith.toLowerCase(Locale.ROOT)) // we have some search prefix
                .sort(TermsOptions.Sort.INDEX)
                .build();

    TermsPage page = solrTemplate.queryForTermsPage(query);
    Iterable<TermsFieldEntry> terms = page.getTermsForField(key);

条款基本上是您的价值观。请注意,您必须优化核心以删除已从已删除文档中删除的值。

以上是关于如何使用spring-data-solr编写查询,返回特定字段的所有值的列表的主要内容,如果未能解决你的问题,请参考以下文章

使用 SolrTemplate 使用 Spring-data-solr 进行枢轴分面

spring-data-solr 选用高版本Cannot locate BeanDefinitionParser for element [solr-server]

使用 Spring-Data-Solr 注入存储库

使用spring-data-solr做solr客户端

Solr7.x学习-使用spring-data-solr

如何在控制台或文件中记录spring数据生成的solr查询