首页 > 解决方案 > 使用spring data elasticsearch注释查询并仅返回特定的嵌套字段

问题描述

使用spring data elasticsearch注释查询并仅返回特定的嵌套字段

版本:</p>

springboot:2.1.7.RELEASE

弹簧数据弹性搜索:2.1.7.RELEASE

弹性搜索:6.5.4


文件:</p>

@Data
@Document(indexName = "test_book", type = "test_book")
public class Book {
    @Id
    private String id;

    private String name;

    private LocalDateTime time;
    /**
     *
     */
    private Publishing publishing;

    /**
     * 
     */
    private Author author;
}

仓库:</p>

public interface BookRepository extends ElasticsearchRepository<Book,String> {

    @Query("{" +
            "\"_source\": {" +
            "   \"includes\": " +
            "       [ \"name\"]" +
            "}," +
            "\"bool\" : {" +
            "   \"must\" : [{" +
            "       \"term\" : {" +
            "           \"id.keyword\" : \"?0\"" +
            "           }" +
            "       }]" +
            "   }" +
            "}")
    Book queryBookNameById(String id);
}

我只是想获取name的数据,这样可以相对节省内存资源。但是我有一个错误,我不能像这样使用它吗?还是只能使用elasticsearchTemplate?

ParsingException[no [query] registered for [_source]
]
    at org.elasticsearch.index.query.AbstractQueryBuilder.parseInnerQueryBuilder(AbstractQueryBuilder.java:332)
    at org.elasticsearch.index.query.WrapperQueryBuilder.doRewrite(WrapperQueryBuilder.java:165)
    at org.elasticsearch.index.query.AbstractQueryBuilder.rewrite(AbstractQueryBuilder.java:279)
    at org.elasticsearch.search.builder.SearchSourceBuilder.rewrite(SearchSourceBuilder.java:921)
    at org.elasticsearch.search.builder.SearchSourceBuilder.rewrite(SearchSourceBuilder.java:80)
    at org.elasticsearch.index.query.Rewriteable.rewriteAndFetch(Rewriteable.java:97)
    at org.elasticsearch.index.query.Rewriteable.rewriteAndFetch(Rewriteable.java:87)
    at org.elasticsearch.action.search.TransportSearchAction.doExecute(TransportSearchAction.java:215)
    at org.elasticsearch.action.search.TransportSearchAction.doExecute(TransportSearchAction.java:68)
    at org.elasticsearch.action.support.TransportAction$RequestFilterChain.proceed(TransportAction.java:167)
    at org.elasticsearch.xpack.security.action.filter.SecurityActionFilter.apply(SecurityActionFilter.java:126)
......

标签: spring-bootelasticsearchspring-data-elasticsearch

解决方案


这目前不适@Query用于存储库的注释。Spring Data Elasticsearch 将注释的值包装为查询值,因此将_source部分包含到查询中。

我们需要向注解 (includesexcludes) 添加额外的参数,以便能够构建正确的查询并使其工作。我将为此创建一个 Jira 问题以跟踪此功能请求。

吉拉问题


推荐阅读