Spring Data Elastic Search Nested Field和NativeSearchQueryBuilder.withFields

时间:2016-04-04 21:35:53

标签: java elasticsearch spring-data-elasticsearch

当我使用NativeSearchQueryBuilder.withFields(...)方法时,我似乎无法返回嵌套字段。

这是我的父对象:

@Document(indexName = "inventory")
public class Inventory
{
  @Id
  private String id;
  @Field(type=FieldType.String)
  private String name;
  @Field(type=FieldType.Nested, index=FieldIndex.not_analyzed, store=true)
  private List<Model> models;
}

这是嵌套的对象:

public class Model
{
   @Field(type=FieldType.String, index=FieldIndex.not_analyzed, store=true)
   private String model;
   @Field(type=FieldType.String, index=FieldIndex.not_analyzed, store=true)
   private Set<String> series;
}

和查询

NativeSearchQueryBuilder nativeSearchQueryBuilder = new NativeSearchQueryBuilder();
nativeSearchQueryBuilder.withQuery(QueryBuilders.matchAllQuery());
nativeSearchQueryBuilder.withFields("models.series");
NativeSearchQuery nativeSearchQuery = nativeSearchQueryBuilder.build();
FacetedPage<Inventory> results = inventoryRepository.search(nativeSearchQuery);

产生的TotalElements = 529 但内容中的每个对象都是这样的(采用JSON格式):

{
   "id":"d5f82880-15bc-45ed-8abb-ff97d0e45da9",
   "name": null,
   "models": null
}

如果我删除了withFields(...)设置,我会回来:

{
   "id":"d5f82880-15bc-45ed-8abb-ff97d0e45da9",
   "name": "Cool Beans",
   "models": [
     {
       "model" : "foo",
       "series" : ["bar"]
     }
   ]
}

我尝试过模型,models.model,models.series,model,series。我无法使用NestedFields的字段。

有什么想法吗?

1 个答案:

答案 0 :(得分:0)

我对弹性搜索字段的理​​解不正确。 rahulroc让我失望。

withFields与源过滤不同。

https://www.elastic.co/guide/en/elasticsearch/reference/current/search-request-fields.html

所以我有效地告诉Spring Data ES这样做:

curl localhost:9200/inventory/_search?pretty=true -d '
{
  "fields" : ["models.series"],
  "query" : {
     "match" : {"name" : "cool"}
  }
}'

当这是我想要的时候

curl localhost:9200/inventory/_search?pretty=true -d '
{
  "_source" : ["models.series"],
  "query" : {
     "match" : {"name" : "cool"}
  }
}'

在我开始添加NestedFields之前,withFields方法适用于我正在做的事情。我正在使用的当前Spring Data ES实现不支持源过滤。

Source Filtering刚刚添加到Spring Data ES 2.0.0.RC1