当我使用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的字段。
有什么想法吗?
答案 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