[英]elastic search filter by documents count in nested document
我在弹性搜索中有这个模式。
79[
'ID' : '1233',
Geomtries:[{
'doc1' : 'F1',
'doc2' : 'F2'
},
(optional for some of the documents)
{
'doc2' : 'F1',
'doc3' : 'F2'
}]
]
Geometries是一个嵌套元素。 我想得到Geometries中有一个对象的所有文档。
到目前为止尝试过:
"script" : {"script" : "if (Geomtries.size < 2) return true"}
但我得到例外:没有这样的属性GEOMTRIES
如果您将字段作为nested
在映射中的类型,则接近的典型doc[fieldkey].values.size()
似乎不起作用。 我找到了以下脚本:
{
"from" : 0,
"size" : <SIZE>,
"query" : {
"filtered" : {
"filter" : {
"script" : {
"script" : "_source.containsKey('Geomtries') && _source['Geomtries'].size() == 1"
}
}
}
}
}
注意:您必须使用_source
而不是doc
。
问题在于您访问脚本中的字段的方式,使用:
doc['Geometry'].size()
or
_source.Geometry.size()
顺便说一下,出于性能原因,我会反规范化并添加GeometryNumber字段。 您可以使用变换映射在索引时计算大小。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.