这代表我的映射:
{
"name": {"type": "string", "include_in_all": true},
"properties": {
"type": "nested",
"properties": {
"name": {"type": "string"},
"value": {"type": "string"}
}
}
如何使用分面搜索来搜索“properties.value”的值?这是一个示例文档:
{
"name": "Testproduct",
"properties": [{
"name": "Color",
"value": "Green"
}, {
"name": "Size",
"value": "M"
}]
}
我想(仅)通过“颜色”属性构建一个多面列表。所以结果应该是这样的:
Red: 7 times
Green: 5 times
Blue: 1 times
这是我到目前为止所尝试的:
{
"size": 1000,
"query": {
"query_string": {
"query": " ... ",
"default_operator": "AND"
}
},
"facets": {
"resolution": {
"nested": "properties",
"facet_filter": {
"term": {
"name": "Color"
}
},
"terms_stats": {
"key_field": "name",
"value_field": "value"
}
}
}
}
如果我执行这个搜索查询,我会得到以下响应:
FacetPhaseExecutionException[Facet [resolution]: value_field [value] isn't a number field, but a string];
我几乎不理解回应,但我不知道我在概念上做错了什么。