当前位置: 首页 > 知识库问答 >
问题:

使用Spring数据elasticsearch查询并仅返回特定的嵌套字段

柯乐童
2023-03-14

是否可以使用spring data elasticsearch返回所有elasticsearch文档的特定嵌套字段?

例如。es数据存储库将如何查找以下查询?

网址: /myIndex/MyType/_search

查询正文:

{
  "_source": [
    "MyNestedObj.myField"
  ]
}

共有1个答案

西门奇希
2023-03-14

使用Spring Elasticsearch数据

不幸的是,1. x版不提供源过滤

import org.elasticsearch.index.query.MatchAllQueryBuilder;
import org.elasticsearch.search.SearchHit;
import org.elasticsearch.search.SearchHits;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.PageRequest;
import org.springframework.data.domain.Sort;
import org.springframework.data.elasticsearch.core.ElasticsearchTemplate;
import org.springframework.data.elasticsearch.core.query.FetchSourceFilter;
import org.springframework.data.elasticsearch.core.query.NativeSearchQuery;
import org.springframework.data.elasticsearch.core.query.NativeSearchQueryBuilder;
import org.springframework.data.elasticsearch.core.query.SourceFilter;
import org.springframework.stereotype.Repository;
import java.util.ArrayList;
import java.util.List;

@Repository
public class MyRepository {

    private final static String FIELD_MYFIELD = "MyNestedObj.myField";

    @Autowired
    private ElasticsearchTemplate elasticsearchTemplate;

    public List<String> findAll() {
        SourceFilter sourceFilter = new FetchSourceFilter(new String[]{FIELD_MYFIELD}, null);
        final PageRequest pageRequest = new PageRequest(0, Integer.MAX_VALUE, new Sort(FIELD_MYFIELD));

        final NativeSearchQuery query = new NativeSearchQueryBuilder()//
                .withQuery(new MatchAllQueryBuilder()).withSourceFilter(sourceFilter)//
                .withIndices("myIndex").withTypes("MyType").withPageable(pageRequest)//
                .build();

        return this.elasticsearchTemplate.query(query, response -> {
            List<String> values = new ArrayList<>();
            final SearchHits hits = response.getHits();
            for (final SearchHit hit : hits) {
                values .add(hit.getSource().get(FIELD_MYFIELD));
            }
            return values;
        });
    }
}
 类似资料:
  • 注释使用Spring数据elasticsearch查询并仅返回特定的嵌套字段 版本: springboot:2.1.7。释放 spring数据弹性搜索:2.1.7。释放 elasticsearch:6.5.4 文件: 存储库: 我只想得到名字的数据,这样可以相对节省内存资源。但我犯了个错误,不能这样使用吗?或者只能使用elasticsearchTemplate?

  • 我有以下POJO 在下面的类中,我想直接检索给定人员的嵌套字段“cars”,其名称作为参数传递,但它返回一个具有null值的列表。 但是,如果在上面的searchHits代码中,我将类更改为Person,如下所示,我将返回pojo Person,其中只填写属性“cars”(所有其他属性检索为null): 但是如何直接检索嵌套的属性车?

  • 问题内容: 我有以下查询: 这将同时返回“匹配”对象(整个文档)和“ inner_hits”对象(嵌套在匹配内部)。 有没有办法让我只返回出现在“ inner_hits”结果中的匹配“查询”元素,而没有获取整个文档? 问题答案: 应该可以通过以下方式 在顶层 禁用source- field 来实现

  • 我是Elasticsearch的新手,我提出了一个问题,Elasticsearch嵌套查询是否只能为嵌套字段返回匹配的嵌套文档。 对于示例,我有一个名为的类型,其中嵌套字段名为 和嵌套查询 我需要的是搜索有提到足球的评论的博客文章,每个博客文章的评论数与足球相匹配(在例子中它数为1,因为另一个评论刚刚提到篮球)。 然而,Elasticsearch似乎总是返回完整的文档,所以我如何才能实现它,或者我

  • 我正在通过jHipster使用Spring Data Elasticsearch支持,并试图更多地了解如何使用搜索来扩展数据库中的一些新关系。 我有了一个新的嵌套关系,它有自己的索引: 我想将结果筛选到特定用户“friend1.id”,并在嵌套文档上搜索匹配的详细信息? 但这似乎没有返回任何结果?

  • 我正在努力学习GraphQL( 我只得到一级字段,比如: 以下是我的模式: 我的解析器: 知道我做错了什么吗?